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How we 



as part of the program, you can ask more of 
your database. Using the emerging industry- 
1 Hi j 1 standard query language. 

•roved Structured 

comes with the most complete 
set of application building 
tools. Including a full report 
writer and screen generator. Plus a family 
of companion products that all work 
together. 

Like our embedded SQLs for C and 
COBOL. So you can easily link your pro¬ 
grams with ours. File-it.T our easy-to-use 



Actually, we didn’t change a thing. 

We just combined it with the best 
relational database management system. 
Introducing INFORMDO-SQL. 

It runs on either UNIX™ or MS™-DOS 
operating systems. And now with IBM’s SQL 




















file manager. And C-ISAM7 the de facto 
standard ISAM for UNIX. It’s built into all 
our products, but you can buy it separately. 

And when you choose RDS, youll be 
in the company of some other good com¬ 
panies. Computer manufacturers including 
AT&T, Northern Telecom, Altos and over 
60 others. And major corporations like 
Anheuser Busch, First National Bank of 
Chicago and Pacific Bell. 

Which makes sense. After all, only RDS 
offers a family of products that work so well 
together. As well as with so many industry 
standards. 


So call us for a demo, a manual and a 
copy of our Independent Software Vendor 
Catalog. Software vendors be sure to ask 
about our new “Hooks” software integration 
program. Our number: 415/424-1300. 

Or write RDS, 2471 East Bayshore Road, 
Palo Alto, CA 94303. 

And well show you how we took a good 
idea and made it better. 


RELATIONAL DATABASE SYSTEMS, INC. 
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High Speed Backup/Mass Storage 
for the AT&T 3B2 Computer 


ACI’slO megabyte cartridge system provides 
dual purpose expansion for the AT&T 3B2. This 
cartridge system provides the fastest 3B2 
backup available and also, unlike streaming 
tape drive storage systems, provides extra 
mass storage as a mountable disk drive. 

As a backup device, ACI’s cartridge system al¬ 
lows complete multi-volume backup. Single or 
multiple files 
may be saved 
to, and restored 
from, removable 
cartridges. 

Individual 
files are easily 
restored from 
multi-volume 
backups. 



As a mountable disk under the Unix operating 
system, the cartridge system allows users to 
create directories on removable cartridges as 
desired. In a multi-user environment, adminis¬ 
trators may find it useful to allow users their 
own cartridges, enabling them to have as 


much disk space as they need in 10MB 
increments. 

In certain situations, the 3B2 user may desire 
greater storage capacity than the standard 32 
MB of the 3B2. ACI’s expansion system has a 
capacity of up to 240 MB of unformatted 24 ms 
fixed disk storage. 

The operation of ACI’s cartridge system is fully 
integrated with the standard AT&T Unix System 
V Release 2 system menus. This allows users to 
backup and restore files as well as to mount 
and unmount file systems by making menu se¬ 
lections. In-depth knowledge of the Unix oper¬ 
ating system is not required, yet those familiar 
with Unix will find the cartridge system works as 
expected with all disk commands. 



Absolute Computers, Inc. 

1106 Clayton Ln. 108E • Austin, Texas 78723 • 512-458-5206 


3B2 is a trademark of AT&T Technologies 
UNIX is a trademark of AT&T Bell Laboratories 
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BEYOND C: 
LANGUAGES PAST, 
PRESENT, AND 
FUTURE 

by David Spencer 

C and other third- 
generation languages 
have had their day. But 
to correctly predict the 
fi ture, you’ve got to 
know some history. This 
month's cover story 
examines past and 
p -esent computer 
lc nguages, then takes 
four enticing glances 
forward at future 
possibilities. 
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FOURTH- 

GENERATION 

LANGUAGES 

DEFINED 

by Tom Mahugh 


Fourth-generation 
computer languages and 
related buzzwords have 


left many in a quandary. 
No need to worry, 
though. Understanding 
the new jargon is as 
simple as learning your 
ABCs. 


48 

PROLOG AS A 
UNIX SYSTEM TOOL 

by John Malpas 

Only minor technical 
obstacles stand in 
Prolog’s way, claims our 
author, who examines 
this possible replacement 
for the C language. 


54 

MODULA-2 KNOCKS 
AT THE DOOR 

by Giacomo Marini 
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Modula-2’s modularity 
and programming ease 
make it a leading 
contender to be the 
language of the 1990s, 
contends our author. 


EXPOSING THE 
PC/UNIX SYSTEM 
CONNECTION 

by Alan Winston 

Don’t give up hope! You 
can save time, money, 
and valuable desk space 
by making the PC/Unix 
system connection. 
Here’s a look at your 
choices. 
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CONCENTRIC^ 
ASSOCIATES, INC. 

WE DON’T 
PRODUCE TRAINING. 


We Produce Shell Programmers, C Programmers, Ada Program¬ 
mers, System Administrators, Kernel Hackers, Doc Preppies, 

and Project Managers. 

• We will work with you to find out what your people need to know. 

• At no charge, we will propose a curriculum tailored so that your people 
are immediately productive. 

• Our instructors will deliver the courses or you can license the courses 
and well teach your teachers. 


WE ARE ALSO COMMITTED TO BRING TO 
MARKET A LINE OF SOFTWARE TGDLS 
TARGETED AT PROGRAMMER PRODUCTIVITY 

The first of these products is: 

shacc-the shell accelerator-is a compiler for the Bourne shell. It translates Bourne shell pro¬ 
grams into C and then invokes the C compiler to produce an "a.out" file. The C code that 
is generated is well-structured and very readable, so it can be further optimized by hand if 
you like. 

shacc allows you to write production code in the Bourne shell: Do the fast prototyping in shell 
and then shacc it and ship it. 


Call us for information about our on-line demonstration. 

shacc 

By Paul Ruel 

Concentric Associates 


SHAOCUP wfih n 
CONCENTRJC) 
ASSOCIATES, INC 


For further information on our Educational Services or shacc, call or write: 

Linda Cranston/ Concentric Associates, Inc/ One Harmon Plaza/Secaucus, NJ 07094 
201-866-2880 
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2700 II 


Now, more than ever, expression of ideas 
through the printed word is a cultural 
imperative. Just getting through a day means 
dealing with massive amounts of information. 
And we each have a duality of roles — we 
consume information, we produce it. 

As consumers of information, we must make 
choices. We choose material that appears more 
interesting, that is credible and clearly 
presented, that expresses a dimension of 
power through its appearance. 

As producers of written information, we 
have the burden of creating that dimension. 

We have the responsibility to insure that our 
expressed thoughts become conveyed ideas. 

Typesetting offers the solution. With the 
ability to choose typestyles and sizes, control 
spacing and position, you can give your 
message the added impact it needs to cut 
through the mass of material competing for 
your readers' attention. Contracts, cor¬ 
respondence, memos, reports, forms, 
documentation, training materials, everything 
you produce can carry the extra dimension of 
power that gets it read and remembered. 

Laser xerography provides the means of 
typesetting in-house, effectively, immediately. 
VLS, through our CompWare* product line, 
provides the means of using laser xerography. 

Call now for more information on 
DX-2700*, software support for the 
Xerox 2700* laser printer; our DWB* 
release for AT&T's 3B* processors; 

VAX/UNIX* BSD Laser Printer support; 
and other CompWare products. 

We'll show you how to express the power in 
your corporate publishing. 


*DWB and 3B arc trademarks of AT&T Technologies; 
DX-2700 and CompWare are trademarks of VLS, Inc.; Xerox 
2700 is a trademark of the Xerox Corporation; UNIX is a 
trademark of AT&T Bell Labs; VAX is a trademark of Digital 
Equipment Corporation. 




The Power of Expression 
The Expression of Power 


VLS INC 44000 OLD WARM SPRINGS BLVD. FREMONT, CA 94538 |415) 490-3555 
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EDITOR’S CONSOLE 



Here’s another “Editor’s Console” you can put in the 
debunking popular myths and industry trends cate¬ 
gory. This time, man/machine interfaces. Countless 
computer newspaper and magazine pages have de¬ 
tailed discussions of the new man/machine interfaces. 
In lay parlance, this means things like mice, windows, 
menus, soft-function keys, on-line help tutorials—in 
short, the stuff that glitzy press conferences, vacuous 
Business Week cover stories, innocuous product re¬ 
views, and the buzzword user-friendly are made of. 

The only problem with all this is that magazine reviews and feature 
articles are as close as most business users will ever get to these prod¬ 
ucts. Now some might say that’s a bad thing, that most business users 
should use these aids in man/machine interaction. 

I, for one, happen to disagree. Indeed, I would strenuously argue 
that most general business users don't want or need a mouse. I know I 
sound like some kind of conservative reactionary, the computer industry 
equivalent of a Jerry Falwell. But consider for a moment that history is on 
my side. 

Every product of this nature yet to come to market has ultimately 
been a flop, failing to achieve its inventor’s goals to revolutionize tech¬ 
nology, capture the popular imagination (and market share), and shift the 
balance of power away from IBM. Not one, I remind you. Not Star, not 
VisiOn, not Lisa I, II, or III (the Macintosh xl), and, now, not the Mac. 

Most of these “innovations” are but the PR and advertising hype of 
Silicon Valley’s version of medicine men, garage mechanics, and soda pop 
salesmen. Indeed, most of these user interface innovations are little more 
than toys, of dubious value to the business user who wants to jot down 
a memo, redo a spreadsheet, or call up a file from the corporate database. 
But we shouldn’t let a few bad apples spoil the lot. 

Not all is lost, however. Real advances in man/machine interfaces 
are being achieved, mostly through fourth- and fifth-generation computer 
languages—in short, the stuff this month’s issue is made of. In the 
meantime, however, users will continue to expand their computer usage 
through and only through the availability of application software that hit 
common chords among vast numbers of users. Otherwise, they’ll just end 
up playing games. 

Elsewhere, observant readers will notice some changes this month 
and last in the lineup of our regular editorial departments. Gone are 
“From the Publisher’s Desk” (and the publisher) and “News from AT&T. ” 
In are a new publisher (Robert A. Billhimer) and “For the Record,” a new 
monthly column of up-to-the-minute news, rumors, and noteworthy 
events. Out last month but back this issue is Bill Tuthill’s “Starter Kit.” 


Philip J. Gill 
Editor-in-Chief 
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It’s a big word these days. And no 
one has a bigger commitment to it than Apollo. 
In fact, we’ve raised the UNIX™ standard to 
new heights. 

We’re the first major computer 
company to implement both AT&TSystem V 
and Berkeley 4.2 on a professional worksta¬ 


tion. So you can run either standard or both 
simultaneously. 

More important, we’re the only 
company that gives you UNIX in a powerful, 
distributed processing environment. One that 
features 32-bit dedicated workstations, high 
resolution graphics, and a high-speed local area 











































network that lets you transparently share infor¬ 
mation and resources. 

Today, the right UNIX standard is 
a choice of standards. For a demonstration of a 
standard that’s anything but ordinary, call 
(617) 256-6600 x4419. Or write Apollo, 330 
BillericaJ Rd., Chelmsford, MA 01824, MS31. 






















































UNIX & TODAY 



TODAY 

• Cure for 
Backlogs 

• Potion f >r 
Portabi y 


Are you dizzy with software application backlogs? You 
need a straightforward cure— TODAY, the UNIX fourth- 
generation language that is breaking time zones in 
software development. 

TODAY runs under UNIX to provide application 
portability across a wide range of machines and with 
a range of databases. Your application developers will 
enjoy a COMPLETE application building environment. 

Features: 

• Non-procedural specification with powerful recur¬ 
sive logic and Decision Tables 

• Synonyms, Menus, Prompts, Helps and Defaults 
for streamlined definitions 

• Tailoring control allowing multi versions of a base 
application 

• Screen Painter 

• A Report Generator which includes a Painter 

• Push-button Self-documentation 

• Audit Trails 

• Source-code security through run-time only 
configurations 

• Developed Applications instantly portable across 
UNIX-based machines 

Visit our booth—No. 2144—at the NCC 85, 

Chicago, Illinois, July 15-18. 

Call TODAY —(408) 727-4464 
Or write: bbj Computer Services Inc. 

2946 Scott Boulevard 
Santa Clara, CA 95054 
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TRENDS 


FOR THE RECORD 


Top of the NeWS . . . Some interesting products made their debuts at the Unix Systems Expo/Spring ’85 at 
San Francisco’s Moscone Center. Leading the list is Relational Technologies Inc.’s new rti Ingres pc Link 
software, a PC-to-Unix system connection that permits the transparent information exchange between Ingres 
date bases on Unix system hosts and IBM and compatible PCs running the most popular applications software, all 
thro ugh a Lotus 1-2-3-like interface (see Multiplex/Ingres pc Link preview in “Exposing the PC/Unix System 
Cornection,” this month). . . Elsewhere on the DBMS front, Unify Corp. inked new OEM deals with at&t for 
the Unix PC and with NBl Inc. for its Unix system-based gear. Network Technologies Inc., also known as 
Neti, unveiled what is apparently the first in its class, an electronic conferencing software package called 
eFi 


orum. . . 


Computer Consoles Inc., whose Officepower office automation system is reviewed in this issue, an- 
nced a new $16,500 floating point option for its 6/32 high-end supermini. Also, CCl’s Irvine, Calif.-based 
irimercial Products Group said it had signed a new OEM agreement with England’s only remaining indigenous 
inframer, International Computers Limited (ICL). ICL has contracted to buy a minimum of 100 6/32s a 
over five years and will also sell CCl’s Officepower software on the 6/32 and other non-CCl-made ICL hard- 
e. Company executives say they have shipped about 100 6/32s so far, with about 40 or so new 6/32s going 
the door every month. They predict ship rates of 100 a month by December, and as many as 1000 next 


nou 
Coi 
mai 
year 
war' 
out 
yealr 

Challenge Issued . . . Also during the Unix Systems Expo, Berkeley, Calif.-based basis Inc. (which stands 
for Bay Area Shared Interactive Systems) said it would donate a valuable Heuer Chronograph to the individual 
or organization who produces the best test of the Unix system’s real-world performance—meaning a set of 
benchmarks that accurately portray Unix system performance in business applications such as word processing, 
accounting, database management, and the like, basis won the watch by being the first to successfully take the 
Plexus challenge, a test later taken by Unix/World Editor-at-Large Bruce Mackinlay. Interested parties should 
contact basis marketing director Gary Babcock for details.. . 

Mis-Fortune ... As predicted, a major shakeup did occur at beleaguered Fortune Systems Corp., 
Redwood City, Calif., the “erstwhile darling” of the Unix system-based supermicro market, but since its IPO, a 
virtual financial dry hole. Officially, April’s shakeup went like this: In a tersely worded press release, Fortune 
disclosed “a number of management changes which it believes will aid the company in achieving 1985 goals. ” In 
plain English, those management changes included promotions and demotions and the layoff of approximately 
10Q staffers “to properly size the company for an anticipated slower growth curve.’ 

Prominent senior-level managers shuffled about were James Ferenz, formerly vice president, manu¬ 
facturing, now senior vice president, operations; and Bob Ruebel, formerly senior vice president, marketing, 
now holding down the new position of executive vice president, corporate development. To top it all off, de- 
spi 


Campbell and Bob Ruebel) that it would show a profit by the fourth quarter ’84, the headquarters on Twin 


e repeated public statements from the firm’s new turnaround management team (headed by ex-Xeroids Jim 


[phin Drive is still awash in a red sea of losses. And the firm projected that revenues for the first quarter ’85 
be “somewhat disappointing,” at 20 to 30 percent below the same quarter last year. Word is that the actual 


Do 
wil 

los 5 for this quarter will be between $1.5 million and $2 million . 


RlimOrS of the Month . . . Those of you anxiously looking to at&t to resolve your communications and 
net working dilemma will apparently have to wait at least until tliis December or next January. That is when, 
sources say, AT&T will unveil the next major release of System V, which will include the touted “Streams” 
communications feature and record and file locking. Till then, Bill Joy’s NFS may well have free reign. . . 

Sli ggish sales forced a major layoff in late April at Sydis Inc., a San Jose, Calif.-based maker of integrated 
voce, data, and text office systems. Sources say that between 40 and 50 percent of the company’s work force 
was let go, amounting to about 50 staffers. Gone are almost all marketing personnel. All this despite some 
big-figure OEM contracts, including one supposedly worth in excess of $150 million with GTE Corp. . . . 
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TRENDS 


FOR THE RECORD 


Microport Corp., the Digital Research Inc. spinof f charted with doing Unix System V ports for com¬ 
mercial OEMs, has been forced to retrench after losing a bid on a contract to do the System V port for the 
upcoming Intel Corp. 80386 chip, according to company insiders. However, the same confidants said the as 
yet unknown winner would be revealed in the next 60 to 90 days or so. . . Meanwhile, Microport chairman Rod 
Turner turned up as executive vice president of marketing at Symantec Inc., Santa Clara, Calif., the software 
firm headed by ex-Lotus Development Corp. honcho Vern Rayburn. Turner, an Ashton-Tate alumnus who 
surfaced from semiobscurity last January to take the Microport helm, will fulfill his Microport duties on a part- 
time basis. Symantec, by the way, bought C&E Software, one of whose founders was ex-DRi vp Gordon 
Eubanks. . . 

Look for a major new graphics software product this month from Visual Engineering Inc., San Jose, 
Calif.. Called Display WorkBench during the development stages, the package is said to be highly modular and 
contain an integrated database along with other such facilities of importance to graphics software developers, 
OEMs, and vars . . . Almost a year after its introduction at Comdex/Spring ’84, NEC Information Systems has 
still to deliver its PC-UX Unix System III option on its highly touted APC-III, IBM-compatible pc. Word is now that 
the Unix system option will be available this month . . . 

Contracts . .. Sun Microsystems Inc. and Apple Computer have announced an oem agreement under 
which Sun will purchase and resell the Apple LaserWriter printer. The agreement calls for the purchase of $10 
million worth of LaserWriters over the next two years . . . Precision Visuals International, the overseas 
subsidiary of Precision Visuals Inc., has signed its first major European license for GK-2000 with BritOil 
PLC ... T he new AT&T Unix PC is available for immediate off-the-shelf delivery from the four distribution or¬ 


ganizations in the Ducommun Electronics Group, Cypress, Calif. . . . 

Pyramid Technology Corp. has signed a major OEM agreement with VMark Computer Inc. of Natick, 
Mass., under which Pyramid will deliver several hundred Pyramid 90x and 90MX supermini computers valued 
in excess of $10 million over a three-year period. VMark makes UniVerse, its new proprietary database man¬ 
agement system designed to execute Prime Information and Pick-like applications in the Unix system 
environment. . . Stratus Computer Inc., Marlboro, Mass., has signed a multiyear OEM packet with System 
Development Corp. (sdc) of Camarillo, Calif., a subsidiary of Burroughs Corp. Under the terms of the agree¬ 
ment, SDC will market Stratus products for sdc’s markets, primarily to the U.S. government and its agencies, for 
air space management, command and control, signal processing, computer security, weapons systems, commu¬ 
nications networks, and office automation. . . 

Computer Consoles Inc., Rochester, N.Y., has had its Officepower integrated turnkey office automation 
system selected to automate the offices of California Governor George Deukmejian. The system will automate 
both the governor’s Sacramento and Los Angeles offices. Initial installation has been completed . . . 

Touchstone Software Corp. has signed a one-year agreement with First Software Corp. of Lawrence, 

Mass. I he agreement provides for the distribution of Touchstone’s Connectables Network software PCworks, 
UniHost, and MacLine. First Software will distribute the Connectables network software nationally as well as 
internationally on a country-by-country basis . . . Systems Strategies Inc., New York, N.Y., a developer of 
IBM emulation software, has signed four OEM agreements worth over $500,000. All four companies have signed 
licensing agreements for Unix-based or Unix-compatible software. They include Siemens (West Germany), 
Tolerant Systems (San Jose, Calif.), Megadata Corp. (Bohemia, N.Y.), and Sequoia Systems (Marlborough, 
Mass.). The firms have selected Systems Strategies to supply IBM emulation packages for distribution with 
their hardware, thus allowing their non-IBM systems to communicate with IBM mainframes . . . 


Noted .. • Tech Valley Publishing Co., the parent of Unix/World Magazine, has announced the ap¬ 
pointment of Robert A. Billhimer as new corporate president and publisher. . . 

Encore Computer Corp. has filed for an initial offering of 5 million shares of common stock at an offering 
price of $5 per share. Hambrecht & Quist Inc. is managing the offering. □ 
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AN SCO PRODUCTION in exclusive association with MICROSOFT CORPORATION 
THE MULTIUSER, MULTITASKING PC BLOCKBUSTER “XENIX NOW!’’ 
starring VISUAL SHELL • MULTISCREEN " • MICNET • THE BERKELEY ENHANCEMENTS 


AND INTRODUCING 


C-MERGE AS THE MS-DOS DEVELOPMENT ENVIRONMENT 


featuring WORLD FAMOUS SCO TRAINING AND SUPPORT for DEALERS • END USERS • ISVs • OEMs 
AND AN INTERNATIONAL CAST OF HUNDREDS OF XENIX APPLICATIONS 
PRODUCED AND DIRECTED BY THE SANTA CRUZ OPERATION 
SCREENPLAY ADAPTED BY THE SANTA CRUZ OPERATION FROM ORIGINAL STORIES BY MICROSOFT AND AT&T 

IN BREATHTAKING SELECTABLE COLOR 

NOMINATED FOR ★ BEST DOCUMENTATION! ★ BEST SUPPORT! ★ BEST TRAINING! 
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Until todiy there was no integrated, multi-user 
productivity system that could be shipped imme¬ 
diately. As a result, a number of previously accepted 
statements about the multi-user software market 
are simply r|ot true. For instance: 

LIE 1. 

There are na readily available multi-user 
integrated productivity solutions. 

NO! 

Prevail is a [jNIX-based, multi-user business 
productivity system which is being shipped and 
used today. Prevail offers business users standard 
office automation products framed in a 
straightforward and easy-to-use window 
environmert. 

Prevail components include: 

□ Word Processing 

□ Spreac sheet 

□ Database Management System 


□ Report 


□ Graphics 

□ Window and System Manager 

□ Communications 

□ Applications Development Language 


' offe 


LIE 2. 

Nobody 
to tailor sy: 

WRONG 

Prevail conn 
business pi 
such depth 
levels of 
the degree 


■ nee 


Writer 


rs software that enables end users 
sjtems for their day-to-day operations. 

! 

• 

bines applications development and 
i oductivity tools and provides them in 
and breadth that people with differing 
ds and skills will tailor the system to 
hey wish. 


LIE 3. 

There is no system on the market which makes it 
easy for software developers and end-users to 
use the same environment. 

NONSENSE! 

Prevail removes the barriers that have been 
making departmental productivity so difficult to 
achieve. Because everyone has different needs 
and skills, Prevail offers people-oriented tools. 
Tools with power and flexibility. 

LIE 4. 

Software suppliers don't offer adequate post¬ 
sale support. 

TOTALLY INACCURATE! 

Inspiration Systems backs Prevail with 
outstanding customer service, training, and 
documentation. We'll be there to help you get 
started and to ensure that you make the most of 
Prevail. Day after day, week after week, we’ll be 
here to answer your questions. 

The truth of the matter is that Prevail is the 
only integrated, multi-user productivity solution 
that can be shipped to you today. 

DISCOVER 
THE WHOLE TRUTH. 



Inspiration Systems, Inc. Production Plaza • Sewickley. PA 15143 • 412/771-4000 


d like to discover the whole truth about PREVAIL. 


NAME. 
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STATE. 
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E _HARDWARE TYPE. 

R □ VAR/DISTRIBUTOR □ OEM 
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□ END-USEI 
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This space is yours. Tell us what were doing right—or wrong. Raise 
issues and ideas that other readers may respond to. Propose projects. 
Reject market trends. Take a stand. 


ALTERNATIVES TO SNA 

Dear Editor: 

There may be “No Way Around Big Blue’s sna” 
(Unix/World, April 1985), but there certainly 
are alternatives to implementing SNA on your 
Unix machine. 

A large-scale IBM (or compatible) communica¬ 
tions will use an IBM 37x5 (or NCR Comten 3690 
or Amdahl 47x5) front-end processor running 
NCP. IBM saw the need to include a gateway to 
X.25 in its architecture, and any large SNA op¬ 
eration has the ability to talk X.25. X.25 is an 
international standard that is already available 
on many Unix system machines (Fortune, Intel, 
Altos, Apollo, etc.). X.25 can communicate to 
sna networks via pdn’s, on private networks, or 
on a single line with up to 4096 virtual circuits. 

It would be better to implement a communica¬ 
tion scheme based on an international standard 
than on a proprietary architecture controlled by 
a company that is a competitor of yours. 

Do we want the company that made MS-DOS a 
“standard” to be in control of our communica¬ 
tions? The world is not all Blue. 

Sincerely, 

Donald Berryman 
Communications Analyst 
TITN Inc. 

Edina, Minn. 

UUCP: ihnp4 ! dicomed ! t i t n ! don 

WRONG IMPRESSIONS 

Dear Editor: 

In your article “Beyond PCs,” by Gilbert and 
Branaman (Unix/World, March 1985), I can’t 
tell if there is a type “0” or a big misunder¬ 
standing. The section titled “The Local-Area 
Network” leads one to believe that AT&T’s 
alternative to the LAN is Ethernet while IBM’s is 
Token Ring. Then it says PBX-based LAN is a 
strong alternative to LANs from IBM and AT&T. 

First of all, Ethernet belongs to Xerox. 

Second, at&t has several offerings to the LAN 


market, two of which are PBX-based. Examples 
of this are System 85 and System 75. Both 
offer simultaneous voice/data over the same 
pairs of wire. This does not require rewiring as 
was implied; that is our whole point —to protect 
the wiring investments already made. 

The second alternative, Information Systems 
Network (isn) from at&t, uses existing twisted 
pair already in place. Fiber optics is used be¬ 
tween concentrator or host computers when 
needed. Twisted pair (the wire used for tele¬ 
phones) goes out to connect terminals and 
other devices. 

There was no misinformation given, but be¬ 
cause of the way it was stated, many people 
probably got the wrong impressions. 

Sincerely, 

Cindy Hostetler 
Technical Consultant 
AT&T Information Systems 
Los Angeles, Calif. 

Editors Reply: Thanks for the clarification. You 
are indeed right, and our authors explained the 
situation pretty much the same as you describe in 
a section of that same article on LANs. Unfor¬ 
tunately, that detailed discussion of LAN require¬ 
ments had to be left out for space considerations. 
We plan to fully address the topic of LANs in our 
December issue on communications and net¬ 
working. Until then, my apologies. 

—Philip J. Gill 

NEEDS A HAND 

Dear Editor: 

I have been a subscriber to Unix/World for 
several months and wish to compliment you and 
your staff on the fine job you are doing in pro¬ 
moting the Unix system and its variants. 

We are users of Xenix, which we run through a 
Radio Shack Model 16, using one terminal and 
four 8-Mbyte hard disks. The system runs well 
for us, but we do have one difficulty with which 
I hope you will be able to help us. 
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^Vhat we need is a simple and quick backup sys¬ 
tem. We have been backing up to floppies, but 
the entire procedure ties up the computer for 
2 bout three hours. Hence, we only do the 
backup once every two or three weeks although 
we would like to have the ability to back up 
c aily or even more often. 

Radio Shack does not have a storage device; I 
have checked with several firms, including 
Hewlett-Packard and Altos, but I have been 
tald that they have nothing either. I eagerly go 
through Unix/World each time it is published 
in the hope that I will find some information on 
backups, but nothing has yet come to my atten- 
t on. Can you help? 

We will be grateful for any assistance you may 
be able to provide. 


so great in the office, why isn’t it being pro¬ 
moted by these vendors as the operating sys¬ 
tem of choice? 

The answer is simply that the Unix system per 
se is not suited to the office, and it takes a lot 
of enhancements to make it even accessible to 
nonprogrammers. Production users need pro¬ 
duction operating systems—so why take a good 
development system and bastardize it to make a 
bad production system? It’s not worth the 
effort, especially when we already have CP/M 
and ms-dos. 

The Unix system, like Pascal and relational 
DBMSs before it, is being sought by ill-informed 
users who mistake popularity for wide appli¬ 
cability. The Unix system has a place, but it 
isn’t in the office. 


Yours truly, 

John T. Zubal 
2969 W. 25th St. 

Cleveland, Ohio 44113 

Editors Reply: Can anybody help? Please write 
Mr. Zubal if you ve got the answer to his needs . 

—Philip J. Gill 
Editor-in-Chief 


STILL THINGS TO DISCUSS 

Dear Editor: 

I would like to address the question “Is There 
Anything Left to Argue About?” which was 
raised in the March 1985 issue of Unix/World. 
he answer,of course,is yes. 

Ih his article Stanley Shein asserts that all the 
major computer vendors regard the Unix sys¬ 
tem as being suitable for the office because 
they all offer a Unix system of some kind. As 
h* points out, they are not babes in the wood; 
tljiey know that you cater to the customer’s 
ants or you lose business. Whether the cus¬ 
tomer’s wants are rational or well informed is 
largely immaterial. As long as the customer 
perceives the Unix system as desirable, the 
vendors will supply it. 

have a copy of a sales memorandum distrib- 
ed to dec’s sales force that makes it clear 
tljiat Ultrix-32 is to be offered only to those cus- 
mers already convinced that the Unix system 
offers them an advantage. If the Unix system is 


Sincerely, 

Roy Hann 

Mountain View, Calif. 

Editors Reply: The Unix system does indeed 
have a place in the office, and a prominent one at 
that. Answer this one question honestly: For 
what environments are the hottest office auto¬ 
mation and electronics publishing products now 
being developed? Only if you answered “For the 
Unix system and the Macintosh” would you be 
right. As for the dec letter you refer to—of 
course, dec is fighting the Unix system, but only 
to keep its installed base locked up under propri¬ 
etary operating systems. Besides, we all know 
that nobody really wants vms! — Philip J. Gill 


BEWARE: READING THIS 
MAGAZINE . . . 

Dear Editor: 

Please be considerate to those of us (“non¬ 
wizards”) on the other side of your magazine 
cover. 

My husband spends many constructive hours 
inside Unix/World, and although it helps him 
become more of an expert in the state of the 
art, I hope he doesn’t evolve into one of those 
futuristic types on your March 1985 cover. 

Sincerely, 

Ellen Faden 
Fremont, Calif. 
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AT&T UNVEILS 
UNIX PC, 
STARLAN 


BY OMRI SERLIN 


A funny thing 
happened on the 
way to the 7300 
inaugural party: 
Not only did 
the machine get 
a new name— 
the Unix PC— 
but, more impor¬ 
tantly, AT&T seems not to be as bull¬ 
ish about its prospects as one would 
expect. 

This mood evidenced itself in a 
series of telltale signs at the San 
Francisco unveiling in March. For 
example, Jack Scanlon, who heads 
the Computer Systems Division in 
AT&T Information Systems (at&t- 
is), suggested that the StarLAN net¬ 
work (not the Unix PC) was “clearly 
the star of this show. ” 

Partly, this attitude is a result of 
history. The Unix pc was commis¬ 
sioned to Convergent Technologies 
by AT&T-is in the days when Archie 
McGill was still around and when it 
was still called American Bell. Jack 
Scanlon and his Computer System 
Division troops, all veteran Bell 
Labs and Western Electric hands, 
at the time were part of a different 
AT&T group and had little enthusiasm 
for the project. They felt (and, 
apparently, still feel) that AT&T 
needs no outside help in designing 
computers, that they could have 
handled the job, and that going out¬ 
side for such equipment adversely 
affects AT&T's prestige as a leader 
in electronic technology. 

Then again, the emphasis on 
StarLAN might well be a welcome in¬ 


dication of acquired savvy. A year 
ago, when AT&T launched its com¬ 
mercial computer entry, the com¬ 
pany’s expectations were naively 
(arrogantly?) driven by a tech¬ 
nological culture that paid very 
little attention to the realities of the 
marketplace. 

A new frame of mind may be 
emerging, forged through AT&T’s 
very unsatisfactory first year as a 
commercial computer supplier. The 
company, one hopes, may have 
learned some important lessons, the 
most significant of which is that IBM, 
not the Unix system, has laid the 
ground rules for the computer mar¬ 
ketplace; and that a necessary condi¬ 
tion for any serious progress here 
must be through coexistence with, 
not departure from, the installed IBM 
base. 

The key hope AT&T pins on 
StarLAN is that it will be the “door 
opener” that will allow AT&T comput¬ 
ers to gain entry into the important 
corporate marketplace, not by re¬ 
placing IBM systems, but by allowing 
the two brands to communicate 
effectively. That is clearly the cor¬ 
rect strategy. 

Unfortunately, AT&T has priced 
the network interfaces and software 
far too conservatively. Unless an IBM 
shop can use existing wiring, there 
isn’t much of a cost incentive for it to 
be more attracted to StarLAN than to 
the Ethernet, 802.3, or IBM PC Net 
alternatives (see Figure 1). 


STARLAN 

The most important feature of 
StarLAN (which is still being drafted 
as a proposed standard in an IEEE 
802.3 subgroup) is that it can utilize 
unshielded twisted-pair telephone 
wiring that already exists in most 
plants and buildings worldwide. 



18 UNIX/WORLD 


StarLAN can use the unused in-wall 
pairs, eliminating the substantial 
labor and cabling costs typically as¬ 
sociated with LAN installations. 

Even when new cabling must 
be installed, this is more readily 
achieved with the lightweight and 
unobtrusive twisted pair, as com¬ 
pared with the unwieldy 0.4-inch 
coaxial cable specified in the Ether¬ 
net and 802.3 standards. Even the 
0.25-inch coaxial cable specified for 
“Cheapemet,” another 802.3 vari¬ 
ant now under consideration, is 
more difficult to handle. 

Low interface cost is another 
advantage of StarLAN. The StarLAN 
interfaces for AT&T’s 6300, IBM PC, 
and the Unix PC are a full $100 
cheaper than the equivalent IBM pc 
Network interface and are $50 
cheaper than the least-expensive 
Ethemet/802.3 interface (see Fig¬ 
ure 1). A further cost reduction will 
occur later this year when Intel be¬ 
gins delivering its 82588 low-cost 
network controller chip. (Current 
at&t StarLAN interface boards carry 
the more expensive 82586 chip.) 

StarLAN has another important 
cost advantage. For its interface to 
the transmission medium, it uses a 
simple, inexpensive RS-422 driver/ 
receiver chip, whereas IBM has to 
use a far more expensive RF modem. 

Of course, there is no free 
lunch. In return for the cost advan¬ 
tages, StarLAN gives up some speed 
(1 Mbps compared to 10 Mbps in 
802.3 and Ethernet, 2 Mbps in the 
IBM PC Net). This is due partly to the 
use of unshielded twisted pair, and 
partly to the more rudimentary “col¬ 
lision detect” logic in the 82588 chip. 

Note that the StarLAN inter¬ 
face board for the AT&T 6300 will, of 
course, fit in the IBM PC and other 
IBM clones as well. This allows the 
IBM PCs to coexist on the same 
StarLAN network that also supports 

Continued on page 23 
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Networking Software So SimpleTo Use, It’s Child’s Play. 


What do you think of when some¬ 
one says “network”? Hardware? 
Complexity? Money? At Touchstone, 
we think networks should be simple. 

TheConnectables Software 
from Touchstone 

The Connectables software — 
PCwoiks™ MacLine™ and UniHost™— 
lets you build-a network out of a 
collec ion of computers. Without 
special hardware, unnecessary 
complexity, or a lot of money. 

UNIX+PC + Macintosh 

Thrqe great computers with differ- 
'Cessors, different operating 
and different data formats, 
nnectables software lets 
nnect these systems together 
ever way you’d like to use 
Jjhare electronic mail, exchange 
of files, run a program on 
system, or use a remote com¬ 


ent prdi 
systems 
The Coi 
you coi 
in whap 
them, 
all 
anothejr 


1 types 


puter’s disk or printer. The only 
hardware you’ll need is a standard 
cable or telephone line and a serial 
data channel. 

It’s So Easy 

The Connectables software will 
take care of all the details — dial the 
right numbers, ask you what you 
want to do, and figure out the rest. 
Move a spreadsheet from your PC to 
a UNIX™ system, or transfer a text 
file from the UNIX system to your 



THE CONNECTABLES’- 1 : 

FAMILY OF COMMUNICATION SOFTWARE RACKAGES. 


Macintosh™ for editing. Print the 
file later on either system, or use 
another computer to backup your 
data. With The Connectables software, 
things that should be easy to do, 
are easy to do. 

Yesterday, Today, Tomorrow? 

Making computers work together 
shouldn’t be a problem. Touchstone’s 
PCworks, UniHost, and MacLine 
software packages are only the first 
three members of The Connectables 
family. Touchstone is committed 
to the continued development of 
software products that solve compat¬ 
ibility problems. Even the problems 
we won’t know about until tomorrow. 



Software Corporation 

909 Electric Avenue, Suite 207, Seal Beach, 
California 90740,213/598-7746 


Please circle Ad No. 82 on inquiry 


PCworks, Un Host, MacLine. and TTie Connectables are trademarks of Touchstone Software Corporation • UNIX is a trademark of AT&T Bell laboratories 

- Macintosh i? a trademark of Apple Computer, Inc.TheTinkertoy designs are used under exclusive license. C1984 CBS, Inc. Copyright 01984 Touchstone Software Corporation. 
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UNIFY isn’t only the fastest and 
most powerful of all UNIX*-based 
data base management systems— 
it’s also one of the simplest to use. 
Which is why some 75 percent of 
those who see our manuals and buy 
a DBMS, buy UNIFY. 

UNIFY guides the nonprogrammer 
through data base development with 
minimal steps, comprehensive menus, 
on-line HELP, elementary Query 
By Forms capability, and clear 
documentation. 



UNIFY expedites applications 
development for users of all skill levels 
with features like PAINT, for effort¬ 
less forms design; SQL, the powerful, 
English-like query language; and a 
menu-handler that lets you quickly 
compile screens, queries and reports 
into menus customized to each user. 

And for the skilled programmer, 
UNIFY offers the most extensive host 
language interface, for limitless flexi¬ 
bility when you need it. 

All of which makes it mighty easy 
to see why UNIFY has been selected 
by more computer manufacturers 
than any other UNIX-based DBMS. 

Judge for yourself. Send for our 
demo kit—disks, tutorial and refer¬ 
ence manuals, all for only $150— 
that shows you how to build virtually 
any application. Contact UNIFY, 
4000 Kruse Way Place, Lake Oswego, 
OR 97034, 503/635-6265. 

Please circle Ad No. 63 on inquiry card. 
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Only Microware's OS-9 
Operating System Covers 
the Entire 68000 Spectrum 


MICROWARE’S OS-9 

UNIX 


ROM-BASED 

FLOPPY-DISK BASED 

DISK-BASED 

SMALL-SCALE 

LARGE-SCALE 

CONTROL 

PERSONAL 

INDUSTRIAL 

TIMESHARING 

TIMESHARING 

SYSTEMS 

COMPUTERS 

SYSTEMS 

SYSTEMS 

SYSTEMS 


HAND-HELD HARDWARE/SOFTWARE SINGLE USER MEDIUM-SCALE 

COMPUTERS DEVELOPMENT SYSTEMS MULTI-TASKING SYSTEMS TIMESHARING SYSTEMS 


SMALL SYSTEMS LARGE SYSTEMS 


Is complicated software and expensive hardware 
keeping you back from Unix? Look into OS-9, the 
operating system from Microware that gives 68000 systems 
a Unix-style environment with much less overhead and 
complexity. 

OS-9 is versatile, inexpensive, and delivers outstanding 
performance on any size system. The OS-9 executive is 
much smaller and far more ef¬ 
ficient than Unix because it's 
written in fast, compact as¬ 
sembly language, making it 
ideal for critical real-time ap¬ 
plications. OS-9 can run on 
a broad range of 8 to 32 bit 
systems based on the 680C0 
or 6809 family MPUs from 
ROM-based industrial con¬ 
trollers up to large multiuser 
systems. 

OS-9'S outstanding: 

C COMPILER IS 
YOUR BRIDGE TO UNIX 

Microwares C compiler tech¬ 
nology is another OS-9 advantage. The compiler produces 
extremely fast, compact, anc ROMable code. You can easily 
develop and port system or application software back and 
forth to standard Unix systems. Cross-compiler versions for 


VAX and PDP-11 make coordinated Unix/OS-9 software 
development a pleasure. 

SUPPORT FOR MODULAR SOFTWARE 
- AN OS-9 EXCLUSIVE 

Comprehensive support for modular software puts OS-9 
a generation ahead of other operating systems. It multiplies 
programmer productivity ana memory efficiency. Applica¬ 
tion software can be built 
from individually testable 
software modules including 
standard 'library" modules. 
The modular structure lets 
you customize and recon¬ 
figure OS-9 for specific hard¬ 
ware easily and quickly. 

A SYSTEM WITH 
A PROVEN 
TRACK RECORD 

Once an underground 
classic, OS-9 is now a solid 
hit. Since 1980 OS-9 has 
been ported to over a hun¬ 
dred 6809 and 68000 
systems under license to some of the biggest names in the 
business. OS-9 has been imbedded in numerous consumer, 
industrial, and OEM products, and is supported by many 
independent software suppliers. 


Key OS-9 Features At A Glance 

• Compact (16K) ROMable executive written in assembly 
language 

• User “shell” and complete utility set written in C 

• C-source code level compatibility with Unix 

• Full Multitasking/multiuser capabilities 

• Modular design - extremely easy to adapt, modify, or 
expand 

• Unix-type tree structured file system 

• Rugged “crash-proof” file structure with record locking 

• Works well with floppy disk or ROM-based systems 

• Uses hardware or software memory management 

• High performance C, Pascal, Basic and Cobol compilers 




OS-9 


MICROWARE SYSTEMS CORPORATION 
1866 NW 114th Street 
Des Moines, Iowa 50322 
Phone 515-224-1929 
Telex 910-520-2535 


Microware Japan, Ltd 

41-19 Honcho 4 Chome Funabashi City 

Chiba 273, Japan 

Phone 0474-22-1747 

Telex 298-3472 


OS-9 is a trademark of Microware and Motorola. Unix is a trademark of Beil Labs. 
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Unix PCs, AT&T 6300s, and AT&T 
3B2 machines. Furthermore, by 
using Microsoft’s ms Net protocols 
in both the Unix system and MS- 
dos, at&t is able to promise (even¬ 
tually) meaningful communications 
between these diverse machines, 
not j jst compatible physical contact. 

The StarLAN schedule calls for 
fourth quarter of 1985 availability of 
Unix/MS-DOS coexistence, meaning 
that Unix PCs, 6300s, and IBM pcs 
can attach to the same network but 
cannot use each other as file or print 
servers. This capability is planned 
for first quarter of 1986, when the 
3B2 with the Unix system will pro¬ 
vide server features for all con¬ 
nect sd pcs— from IBM and at&t. 


INSIDE EDGE 


Unfortunately, when the cost of 
networking software is added to the 
interface costs, AT&T's StarLAN does 
not seem to have any dramatic edge 
over Ethernet, 802.3, or the IBM pc 
Net, except where existing unused 
telephone wiring is available to elim¬ 
inate cabling costs. The lack of a 
clear-cut cost advantage detracts 
substantially from StarLAN’s strate¬ 
gic role as a “door opener.” 

THE UNIX PC 

A year ago, the Unix PC and its jazzy 
System V software would have been 
dazzling, dramatic, and compelling. 
Today, sadly, the system is a tad 
late. 


Today, buyers looking for soft¬ 
ware ergonomics (windows, icons, 
mouse) have a much more cost- 
effective choice in the Apple Mac¬ 
intosh, not to mention the less ex¬ 
pensive and fancier Atari models due 
to be released sometime this year. 

Buyers concerned with stan¬ 
dards and availability of software al¬ 
ready have a good choice in the ibm 
PC/AT, which is at least equal to the 
Unix pc in basic power and which is 
similarly priced. The PC/AT features 
not only the MS-DOS standard but 
also the optional multitasking, mul¬ 
tiwindow TopView environment. 
And, for those interested in multi¬ 
user operation, Xenix on the IBM 
pc/at fits the bill. 
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Available for: 

IBM PCs, 
clones, 
other PCs, 
minis and 
mainframes 

not yet 

Unix PC, 

AT&T 6300, 
IBM PC, 
clones, 

AT&T 3B 

IBM PC 
only 

Apple MAC 
only 


* Nominal, for the AT&T version 

** Cost source: 802.3—3Com/IBM PC; StarLAN—AT&T 6300/IBM PC, UNIX PC. 
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Buyers who prefer the AT&T 
logo over the IBM logo can get many 
of these advantages by buying the 
AT&T (Olivetti) PC 6300, which costs 
less and has just been enhanced 
with a color monitor and Xenix 
availability. 

Who, then, would choose the 
Unix pc? The answer appears to be 
those already hooked on the Unix 
system. For them, the Unix pc is 
clearly the most interesting, most 
“civilized/’ and most cost-effective 
Unix system engine ever. Unfortu¬ 
nately, Unix system hackers are not 
the audience AT&T must have if the 
Unix PC is to be a hit. 

AT&T will probably win a good 
deal of business away from Fortune 
Systems, Altos, and the Tandy 
16/16B/6000 family. But it is doubt¬ 
ful that the Unix PC will draw new 
constituencies. On announcement 
day, AT&T was unable to disclose 
any major orders from any credible 
source. The one contract that was 
announced, nominally valued at $1 
million, was with an obscure firm 
called pc One. 

Given these and other uncer¬ 
tainties, it would not be surprising if 
the 40,000 units AT&T is reputed 
to have ordered from Convergent 
prove to be about twice the quantity 
actually needed. 

A LOOK UNDER THE 
HOOD 

The Unix PC is powered by a 
10-MHz, 68010 microprocessor unit 
that supports demand paging. It 
comes with 512K bytes of memory 
and has three expansion slots for ad¬ 
ditional 512K-byte memory boards 
(for a total of 2 Mbytes) or for pe¬ 
ripheral control boards. The expan¬ 
sion bus, incidentally, is proprietary. 
The computer has a 12-inch, high- 


System 

Points* $/Point 

AT&T Unix PC** 

2164 

3 

CT MiniFrame 

2102 

4 

IBM PC/AT*** 

1747 

5 

NCR Tower XP 

2146 

8 

Zilog 8000-12 

2170 

9 

AT&T 3B2 

1387 

11 

Plexus P35 

1746 

13 

Altos 586 

857 

13 


* Higher performance rates more 
points 

** With 1-Mbyte RAM, 20-Mbyte 
disk 

*** With floating point copro¬ 
cessor 


FIGURE 2: YATES VENTURES 
UNIX PC BENCHMARKS 


Memory 

Hard Disk* 

Price 

512K bytes 

10 Mbytes 

$5095 

1 Mbyte 

10 Mbytes 

$5495 

512K bytes 

20 Mbytes 

$6190 

1 Mbyte 

20 Mbytes 

$6590 

512K-byte 

expansion 

$1195 


board 


Software 


Unix System V “core" 

$495 

Development tools 

$395 

Utilities 


$495 


* 1 320K-byte floppy included. 
Source: Yates Ventures Inc. 


FIGURE 3: PRICING FOR THE 

UNIX PC 

Unix PC w/Unix V 

$6190 

PC/AT w/MS-DOS* 

$6205 

PC/AT w/Xenix 3.0 

$6535 

6300 w/Xenix 3.0 

$5620 

* Add $149 for TopView. 



FIGURE 4: COMPARATIVE 
CONFIGURATION PRICING 
FOR AT&T UNIX PC, IBM 
PC/AT, AND AT&T PC 6300 


resolution, bit-map monochrome 
display of 720 by 348 pixels. It also 
includes a 103-key keyboard, a 
three-button mouse, and a 300/ 
1200-baud modem as standard 
gear. Built-in hard disks of either 
10 Mbytes or 20 Mbytes are of¬ 
fered and are said to be immediately 
available. 

Yates Ventures of Palo Alto, 
Calif., has tested the machine, along 
with several others, using Aim 
Technology’s Suite II benchmarks, 
and concluded that the Unix PC pro¬ 
vides the best “price-per-point. ” 
The more significant results are re¬ 
ported in Figure 2. 

Note, incidentally, that both the 
Unix pc and the IBM PC/AT appear to 
be handily outperforming the AT&T 
3B2, which costs about three times 
as much and which uses the vaunted 
AT&T (nee BellMac) 32-bit mpu. An¬ 
nounced pricing for the Unix pc fol¬ 
lows in Figure 3. 

The most nearly comparable 
configurations (512K byte/20 
Mbytes) for the Unix PC, PC/AT, 
and 6300 are shown in Figure 4. 

As usual, point-by-point com¬ 
parison is complicated. The Unix PC 
for example, has a built-in modem, 
and its screen has substantially 
higher resolution than those of the 
other two. On the other hand, the 
PC/AT has more expansion slots 
(eight versus the Unix pc’s three) 
and, with Xenix, can accommodate 
more memory (3 Mbytes versus the 
Unix pc’s 2 Mbytes). Both the 6300 
and the PC/AT have color monitor op¬ 
tions, but the Unix PC has mono¬ 
chrome only. 

‘CIVILIZED’ UNK 

By far the most interesting aspect of 
the Unix pc is its “core” System V 
software. This software (which is 
entirely unbundled) complies with 
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the recently released System V In¬ 
terface Definition (svid) book and is 
bas;d on Release 2. But for the first 
tim; at&t has addressed several of 
the most troublesome deficiencies in 
the Unix system, especially the sys¬ 
tem’s notoriously user-hostile inter¬ 
face. As Jack Scanlon put it, “We 
have civilized Unix.” 

This has been accomplished 
with a software component called 
the “User Agent,” which is re¬ 
sponsible for managing a multiple- 
window, mouse-controlled user 
interface. Details on the implemen¬ 
tation of this component are sketchy 
so far; in all likelihood, it is a super- 
shell” that allows multiple windows 
be onging to different tasks (all 
spawned by the same user) to ap¬ 
pear on the same screen. The User 
Agent supports a clip-board facility 
for interwindow data transfer, al- 
tb )ugh, again, details on the types of 
transfers allowed are missing. On 
the whole, it appears that the User 
Agent has done a reasonable job 
of creating a Mac-like, software- 
ergonomic interface on top of the 
Unix system. 

It is not entirely clear yet to 
w lat extent this interface is visible 
or usable by the applications pack¬ 
ages. I suspect that few of the 28 
applications currently released for 
the Unix PC take good advantage of 
the new user interface. 

Any future application that does 
so will immediately become incom¬ 
patible with all other Unix system 
variants, including System V on the 
3 3 line. AT&T staffers indicate that a 
compatible User Agent is being de¬ 
veloped for the 3B line and that it 
will eventually be available as a stan¬ 
dard System V option. No timetable 
for these developments has been 
r ■'leased 

Interestingly, the Unix PC ver¬ 
sion of the Unix system supports de¬ 


mand paging, the first non-Berkeley 
version to incorporate such a fea¬ 
ture. Record locking is also sup¬ 
ported, although it isn’t yet clear 
how efficiently this is accomplished. 
In any case, it isn’t terribly relevant 
until real multiuser configurations 
emerge. 

Another interesting capability 
in the “core” software is the tele¬ 
phone management package, which 
manages two telephone lines (one 
for voice, one for data), maintains a 
directory, performs automatic dial¬ 
ing and the rest of the typical fea¬ 
tures found in such packages. A 
dumb-terminal emulator completes 
the core package. 


OTHER ANNOUNCEMENTS 

Along with the Unix PC, AT&T un¬ 
veiled a series of enhancements to 
the PC 6300 and a new telephone 
management “Personal Terminal.” 

Among the 6300 enhancements 
are the following: a 20-Mbyte disk, 
a color monitor, a Communications 
Manager card (providing a modem 
and some telephony management 


News Summary: Sobered by a 
hard first year as a commercial 
computer supplier, AT&T now 
seems to pin more of its hopes 
on the StarLAN network, rather 
than the Unix PC (nee 7300). 
AT&T also unveiled enhance¬ 
ments and software (including 
Xenix) for the 6300, hoping to 
revive its sagging fortunes and 
capitalize on PC/AT delays. Also 
unveiled: an attractive AT&T- 
made telephone-terminal; un¬ 
fortunately, it works only with 
digital ports in AT&T’s S/75 and 
S/85 PBXs. 


functions, including a 200-entry di¬ 
rectory), and, most significantly, 
Xenix 3.0. The port was done by 
The Santa Cruz Operation, which 
handles Xenix on non-286 imple¬ 
mentations. 

Also unveiled for the 8086- 
based 6300 were a mouse, an 8MHz 
8087-2 math coprocessor, and an ex¬ 
ternal box with a 30-Mbyte disk and 
a tape backup system from Mountain 
Computer. 

The soft screen Personal Ter¬ 
minal (pt) is a $1795 desktop tele¬ 
phone management system. The 
soft screen (actually a gel layer over 
the CRT face) actually “gives” to the 
touch, which is a more pleasant sen¬ 
sation than the hard touch screen 
on the hp150, for one. All functions 
can be controlled by touching the 
screen, so a keyboard is $100 extra. 

The key problem is this: Be¬ 
cause we still live in a largely analog 
world, the pt cannot be connected to 
any plain telephone line. It can only 
be attached to a digital port on the 
at&t S/75 or S/85 pbx. Curiously, it 
can’t even attach to another pt with¬ 
out an intervening at&t pbx digital 
port. 

What about the second product 
(supposedly also a phone terminal) 
that Convergent Technologies is 
known to be working on for AT&T? 
This is apparently still coming. 

By the way, with the Unix pc, 
at&t is violating its own silly rule 
that the term Unix must always be 
followed by the word system. □ 


Omri Serlin heads 1TOM International, a 
Los Altos, Calif.-based research and con¬ 
sulting firm. He is the editor and pub¬ 
lisher of FT Systems and of Supermicro, 
newsletters that cover developments in the 
computer industry. 
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BEYOND C 

PROGRAMMING LANGUAGES 

Past, Present, Future 


pnD^TD 2 ! third-generation languages such as C and 
tUKl KAN will have to move aside at some point for a 
new family of fourth-generation languages 


A t 30 years old, fortran is 
graying at the temples; 
third-generation program¬ 
ming languages are in their 
heyday. So you are probably won¬ 
dering how we will speak to com¬ 
puters during the next decade. If 
current projections hold true, com¬ 
puters will seem (and talk) more like 
us fairly soon. In order for that 
to happen, however, current third- 
generation computer languages 
(such as C and fortran) will have to 
move aside for a new family of 
fourth-generation languages. 

Have no fear, though. As com¬ 
puter architectures and program¬ 
ming methodologies have come to 
simulate human thinking more 
closely, programming languages 
have increasingly abandoned the 
procedural approach (how machines 


BY DAVID SPENCER 


do something) in favor of a non¬ 
procedural, functional one (what is 
to be done). As the address-related 
recall capability of the micro¬ 
processor is transformed into the 
associative recall of the brain, high- 
level languages (hlls) move closer 
to, and will eventually be replaced 
by, the very high-level languages 
(vhlls), also known as fourth- 
generation languages. 

To belong to the fourth gener¬ 
ation, a language must have crossed 
the threshold of a world where the 
programmer specifies the task to 
be done to the point where the 
knowledge of how to do the task is 
contained in the language itself. 


Historically, languages have moved 
further from the machine level, be¬ 
coming more abstract with each 
generation. To understand fourth- 
generation languages, you must first 
have some idea of what came 
before. 

First-generation languages 
were little more than machine code, 
which was closest to the computer’s 


































‘What’ll it take to build the best 
computer system in history?” 


“Full, virtual UNIX and super¬ 
minicomputer perforrnanee for 
starters.” 
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“The question is, can we do it on a 
micro? And on schedule?" 


“ We've been thinking about 
National's Series 32000family!’ 


“As long as I don't have to code 
my way around an incomplete 
chip set” 


“It’ll be Art” 


Finally there’s a 32-bit 
microprocessor that gives 
you any UNIX versionyou want, 
and all die development tools 
you need. 


Tb develop an advanced micro¬ 
computer software system, you 
need minicomputer architecture, 
development tools, and high 
level language support. Of all the 
32-bit microprocessors available 
today, only Series 32000” gives you 
this ideal development environ¬ 
ment. Series 32000 supports all : 
major implementations of UNIX”' 
including an AT&T validated 
System V with virtual memory, 
so you can choose the version 
you prefer. 

It’s also the only 32-bit family 
complete with memory manage¬ 
ment, floating point, timing, 
interrupt and DMA control units, 
so you don’t waste time writing 


routines to make up for hard¬ 
ware deficiencies. So if there’s 
a new microprocessor based 
system in your plans, only Series 
32000 can get both software 
and hardware off the drawing 
board today. 

For all the facts, write to: 
Series 32000, MS 23-200 
[National Semiconductor 
2900 Semiconductor Drive 
P.O.Box 58090 
Santa Clara, CA 95052-8090 


National 

JuA Semiconductor 

We’re doing it. 


Please circle Ad No. 42 on inquiry card 
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flip-flopping switches. Each set of 
ones and zeros represented current- 
on/current-off settings. The steps 
for even a simple operation were 
necessarily very discrete and 
seemed artificial in their total lack of 
assumed information. Arithmetic 
was all done in binary, and how a 
program was coded directly mir¬ 
rored how an operation was per¬ 
formed by the machine. 

The second generation brought 
assembly languages, which sepa¬ 
rated operations (instructions) from 
operands (data) and substituted 
names for binary numbers. Assem¬ 
bly languages added a layer of 
address-related recall to the pro¬ 
grammer’s repertoire as assembler 
programs did the tedious, error- 
prone work of putting machine code 
together. Assembly languages were 
purely procedural because addition/ 
subtraction involved the load-move- 
store of binary data. A simple oper¬ 
ation still took many discrete steps, 
however, and decisions were made 
according to condition tests—the 
state of the machine’s registers— 
instead of the task’s inherent logic. 


THIRD-GENERATION HLLs 

The third-generation HLLs gave ab¬ 
straction an algebraic form. State¬ 
ments subsumed a greater number 
of incremental steps. Choices of ac¬ 
tion based on logical conditions re¬ 
placed the comparisons of register 
contents and condition tests, moving 
closer to the human perception of 
the job to be done and away from the 
machine’s demands for a binary 
representation. 

In an article entitled “Program¬ 
ming Languages,” James W. Hunt 
proposes task-centered criteria for a 
good language. Any HLL should allow 
the programmer to design programs 


easily, document programs, debug 
programs, move programs between 
machines (portability), verify a pro¬ 
gram’s correctness, and compile 
parts of a program separately. 

These criteria are met to some 
degree by most widely used hlls: 
fortran, COBOL, Pascal, and C. 
Some functions associated with 
fourth-generation vhlls also appear 
in existing languages. Ada, for in¬ 
stance, employs a class concept to 
abstract data structures and also al¬ 
lows a basic type definition to incor¬ 
porate new items in the class or to 
be changed in response to specified 
behaviors. 

If current projections hold 
true, computers will seem 
(and talk) more like us 
fairly soon. 

A similar extension to C, called 
Objective-C, seeks to make object- 
oriented programming part of the 
Unix system repertoire. Ada, some 
Pascals, and Modula-2 provide 
concurrency, which allows separate 
processes to share resources, in¬ 
cluding the CPU. But these languages 
are not true members of the fourth 
generation because their syntactical 
structures haven’t really changed. 

DIFFERS FROM ITS 
PREDECESSORS 

As I said before, a fourth-generation 
language differs from its prede¬ 
cessors in the degree to which it 
minimizes the user’s need to specify 
machine behavior. Heather Bryce, in 
an article in Electronic Design, lists 
the general characteristics of fourth- 
generation languages: 


(one) designed for on-line op¬ 
eration; 

(two) easily used by nonpro¬ 
fessional programmers (generally, 
users should be able to learn a sub¬ 
set of the language in two days and 
get satisfactory results); 

(three) employs a database man¬ 
agement system (dbms) directly and 
requires one-tenth the number of in¬ 
structions necessary for coding in 
COBOL or pl/1; 

(four) uses nonprocedural code 
and makes intelligent default as¬ 
sumptions where possible, encour¬ 
ages structured code, produces 
code that is easily understood and 
maintained by others, and allows 
easy debugging of programs. 

According to Greg Blanpied, 
Xerox vice president of technology 
development, fourth-generation lan¬ 
guage is an umbrella term that 
usually covers four areas of new 
software; 

(one) presentation languages, 
such as formal query languages, nat¬ 
ural query languages, reporting, and 
graphics; 

(two) specialty/specialized func¬ 
tions, such as spreadsheets, mod¬ 
eling, analysis, and simulation; 

(three) application generators, 
usually for COBOL; 

(four) vhlls, including such 
nonprocedural languages as lisp and 
Forth. 

The decisions to be made in 
each area reflect the needs of the 
user. For example, a growing num¬ 
ber of users are primarily ordinary 
business people whose needs may 
be served by different capabilities of 
each area. Such users generally 
want the presentation languages, 
coupled with some DBMS system, to 
give them easy access to a com¬ 
pany’s huge information system 
without becoming programmers or 
being totally dependent upon man- 
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agement information systems (mis) 
staff. 

They often need a special pro¬ 
gram for predicting the results of 
business decisions and modeling 
scenarios based on hypothetical situ¬ 
ations or predictions. They don’t 
want to wait for mis to make changes 
in existing programs; instead, they 
want to use COBOL program gener¬ 
ators that tailor general programs to 
their specific needs. And they need 
decision-support systems (some¬ 
times called expert systems) to ana- 
lyz s and extract data based on 
knowledge stored in the system. 

Fourth-generation languages 
ard generally one of three types: 
declarative, functional, or object- 
oriented. Declarative, or rule- 
based, languages use a set of oper¬ 
ators to define the relationship 
be ween data. Once all the rules are 
established, the program executes 
them (Malpas and O’Leary, 1984). 
Functional languages apply mathe¬ 
matical expressions to data to get a 
result. The relationships come from 
applied mathematics, and the pro¬ 
gram has no constructs that change 
the original data. Each statement is 
executed independently, and the 
of the machine does not affect 
program in any way. 

In object-oriented programs, a 
^struct called an object contains 
data and commands to which the 
a responds. Objects can be or- 
ilrrized into classes and analyzed for 
common features, “so that conclu¬ 
sions can be drawn or deductions 
made about the data” (Hindin, 
1984). 


WHAT COMES AFTER C? 

Many people consider the Unix sys¬ 
tem and the C language to be the 
ultimate children of the third gener¬ 


ate 


ation. But acceptance by systems 
programmers does not necessarily 
lead to general acceptance by the 
rest of the computing world. The 
Unix system and C form one kind of 
programming environment. How¬ 
ever, several factors will determine 
whether that environment will sup¬ 
port fourth-generation languages as 
well. 

DBMS, the user interface, menus 
and windows—whole issues of vari¬ 
ous publications have been devoted 
to the ways in which the Unix sys¬ 
tem can be tamed and brought into 
the “user-friendly” world now inhab¬ 
ited by the Sun workstations and 
Apple Macintosh systems (see “Ref¬ 
erences”). But the languages them- 


Fourth-generation 
languages are generally 
one of three types: 
declarative, functional, 
or object-oriented. 


selves, the vhlls used to implement 
and control such systems, will still 
have to become less machine- 
oriented before the Unix system 
loses its “fit for true hackers only” 
reputation. 

Specific implementations of ex¬ 
isting languages such as C and Pascal 
often provide a programming envi¬ 
ronment in which fourth-generation 
characteristics might be incorpo¬ 
rated. Proponents of the Unix sys¬ 
tem and C, for example, may sug¬ 
gest extensions to bring C into the 
fourth generation (Cox, 1983, 1984) 
or the addition of a widely used func¬ 
tional language to the Unix and C 
environment (Saunders, 1984). 

Building the next generation’s 
language on top of the current one is 


a common and sensible approach, 
considering the time needed to start 
from scratch. It remains to be seen 
whether C, which most closely re¬ 
sembles assembly language, is the 
best third-generation base for such 
development. Adding an object- 
oriented component or fourth- 
generation interface to an effective 
Pascal implementation (such as 
Pascal-2) would be equally practical 
approaches. 

Adding languages is a relatively 
easy way to make the Unix system 
accessible. Two special-purpose de¬ 
clarative languages, make and 
yacc, for example, are already part 
of the Unix system’s utility set. With 
relatively little training, users of 
these utilities can greatly increase 
their productivity (Malpas and 
O’Leary, 1984). Query languages 
accompany many of the relational 
databases available for Unix-based 
systems. General-purpose declar¬ 
ative languages are the next step. 
Prolog, for example, offers in¬ 
creased efficiency for users and for 
machines. William Wong claims that 
“Prolog compilers on larger ma¬ 
chines generate code that is as effi¬ 
cient as C or LISP so that program¬ 
ming logically does not necessarily 
imply inefficiency” (Wong, 1984). 


FUTURE LANGUAGES 
FOR THE UNIX SYSTEM 

For the Unix system, the new 
languages developed by artificial 
intelligence (ai) researchers are gen¬ 
erally expected to succeed the third- 
generation languages now in use. 
lisp and Prolog are most often men¬ 
tioned; apl and Forth are less prom¬ 
inent, perhaps with good reason. To 
give you a taste of each, without get¬ 
ting bogged down in academic gen¬ 
eralities or technical specifics, sup- 
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country *— 4 6 p ’usa india china brazil’ 
data <- 4 2 p 203 3 548 1 800 4 108 3 
density data[;l] + data[;2] 
max <— [/density 

mostdense <— (max = density) / [1] country 


FIGURE 1: A SAMPLE PROGRAM IN APL 


pose we solve a simple problem with 
a demonstration program in each 
language. 

This problem comes from the 
best-known book on Prolog (Clock- 
sin and Mellish’s Programming in 
Prolog , 1981). In a database, we 
have four countries. For each 
country, we know the population (in 
millions) and the size (in millions of 
square miles). From that data, we 
want to know each country’s popu¬ 
lation density and relative informa¬ 
tion such as the country with the 
largest area, largest population, or 
greatest population density. 


APL 

apl (A Programming Language) was 
an early attempt to program accord¬ 
ing to the logic of the problem rather 
than to the architecture of the ma¬ 
chine. Originally a notation for ap¬ 
plied math algorithms, apl has been 
adopted by IBM and DEC and is now 
available on supermicros. 

Proponents tout apl's terse 
form, simple rules, and concise rep¬ 
resentation of concepts through 
graphic symbols. You enter calcula¬ 
tions as if you were using a 
calculator. Figure 1 illustrates our 
sample problem in apl. The first two 
lines establish our database. The 
“country” matrix has four items; 
each item has six characters. The 
“data” matrix is a corresponding ma¬ 
trix of four items, each with two 


numbers. The last three lines define 
the relationships as mathematical 
calculations. 

To compute the density, we di¬ 
vide the first element of each item 
pair in the data matrix by the second 
element. In the fourth line, the func¬ 
tion symbol for “maximum” is com¬ 
pressed onto density with the func¬ 
tion symbol (“/”). Compression 

Many people consider 
the Unix system and the 
C language to be the 
ultimate children of 
the third generation. 

allows one element to be picked 
from a group, in this case the largest 
one. Using this same technique, the 
final line gives us the name of the 
country with the highest population. 

I can hardly discuss APL without 
mentioning the “funny symbols”; 
they are the focal point, it seems, for 
the real debate about apl’s use¬ 
fulness as a language, apl’s features 
may appeal more to mathematicians 
than to business people. Its creator, 
Kenneth Iverson, offers in his book 
A Programming Language this in¬ 
centive: “The descriptive and anal¬ 
ytic power of an adequate program¬ 
ming language repays the effort 
required for its mastery.” The de¬ 
gree to which apl rewards casual 


users is debatable: Other languages 
allow users to concentrate on the 
problem, free from “concern with 
computer-oriented details. ” And 
these languages use more familiar 
symbols. 


LISP 

lisp stands for List Processing Lan¬ 
guage (not Lots of Inconsequential 
Silly Parentheses). It was one of the 
first Al languages to become well 
known outside Al research centers. 
Popular architectures for Unix sys¬ 
tems, such as the Motorola 68000, 
have allowed LISP to reveal its true 
potential. 

Several lisp features are a 
definite move toward associative 
memory recall. One such feature is 
modularity: Data structures can be 
linked to form larger ones. By 
changing a set of pointers, you 
change the relative location of the 
structure. As a result, the essen¬ 
tially dynamic allocation of storage 
areas replaces the lengthy defini¬ 
tions of parameters for each pro¬ 
gram. lisp also provides “automatic 
garbage collection” as part of its effi¬ 
cient management of memory. 

Figure 2 shows how to solve 
our demonstration problem with a 
lisp program. As you can see, the 
program in Figure 2 requires little 
more than a knowledge of the re¬ 
lationships between the data. Using 
English words or recognizable ab¬ 
breviations, we define those rela¬ 
tionships in the function definitions. 
In the applications definition, the 
relationships may be ordered to pro¬ 
duce the desired results. Most com¬ 
puter manufacturers are offering 
lisp or Common lisp (a more recent 
and more consistent implementa¬ 
tion) as part of their system soft¬ 
ware packages. 
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De f pop lambda X 

(cond (eq X ‘usa’) 203) 
(eq X ‘india’) 548) 


) 

(dlel 


f area lambda X 
(iond (eq X ‘usa’) 3) 


Function Definitions for China, and Brazil, same as above 
a 


ending parenthesis matches the one before cond 


Function Definitions for India, China, and Brazil, same as above 
-ending parenthesis matches the one before cond 


Define DENSITY lambda X 
(iiv (pop X) (area X)) 


(DENSITY india) 

i 

fig] 


(iiv (pop india) (area india)) 


-Application Definition begins 

the X is replaced by the condition india 


URE 2: THE DEMONSTRATION PROBLEM IN LISP 


pop(usa, 203). 
pop(india, 548). 
pop(china, 800). 
pop(brazil, 108). 

area(usa, 3). 
area(india, 1). 
area(china, 4). 
area(brazil, 3). 

density(X,Y) :- 

pop(X, Pop), area(X, Area), 


Facts 

Rule 

Y is pop/area. 


Fit URE 3: THE SAMPLE PROGRAM IN PROLOG 


PROLOG 


gr; 
ma 
in 
obj 
log 
cla i; 


Prolog (the name stands for Pro- 
amming in Logic) allows you to do 
ay of the same things you can do 
lisp. Both languages employ 
ict-oriented relationships. Pro¬ 
’s basic relationship is the Horn 
se, a predicate calculus formula 
tha|t contains only one conclusion. 
Prolog uses a rule-based search 


to manipulate the data in our sample 
problem, a slightly different ap¬ 
proach from lisp’s function/applica¬ 
tion definitions. Facts are added to 
the database and are then inter¬ 
preted according to the rule. 

The statements in Figure 3 
headed by p o p and area are clauses 
stating the facts from which conclu¬ 
sions may be found if we know the 
population and area of X and divide 


the population by the area. 

Prolog is heavily endorsed in 
Japan and England, and many Amer¬ 
ican firms are using it as an interface 
to Unix system databases. 

FORTH 

Forth is more compact than lisp, 
so it’s more popular on current 
microcomputers. It’s also very 
transportable and can do real-time 
applications. 

A Forth routine consists pri¬ 
marily of addresses that point to 
commands written in machine code, 
“primitives” in Forth terminology. 
The user’s instructions, called “sec¬ 
ondaries, ” are written in primitives, 
and all secondaries for a program go 
into a dictionary. The syntax of the 
language is a string consisting of 
Forth words separated by spaces. 
Subroutines are called implicitly by 
“words” that start actions. 

The big difference between 
Forth and other functional languages 
is mostly a matter of applicability. 
Like apl, Forth’s syntax is terse and 
specialized, but unlike APL, it would 
be very difficult to do even our sim¬ 
ple demonstration program. We 
would have to extend the language 
by entering new words into Forth’s 
dictionary, or we’d have to do our 
arithmetic using registers and a 
stack, as we would in assembly 
language. 

Forth is a machine-level pro¬ 
grammer’s language. Even more 
specialized than apl, Forth is an 
object-oriented language for those 
who want to manipulate the com¬ 
puter itself. 

TOO SOON TO CHOOSE? 

Fourth-generation languages may be 
common about 10 years from 
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now. However, government funding 
might accelerate the process and 
make micro-based artificial intel¬ 
ligence software available even 
sooner. But success of any one lan¬ 
guage or product will probably de¬ 
pend as much on the marketing of 
the product as on the technical 
development. 

Harvey J. Hindin, special fea¬ 
tures editor for Computer Design, 
expressed skepticism about the 
readiness of ai languages in an article 
(Hindin, 1984) on the new software: 
“Prolog may end up being funda¬ 
mentally flawed just because it is a 
logic-based language. It turns out 
that logic-based languages (some 
with even more features than Pro¬ 
log) have been proposed before and 
found lacking. They have turned out 
to be duds because logic-based lan¬ 
guages are not flexible enough for 
the real world. . . . Other issues in 
the great debate between lisp and 
Prolog await the test of time. ” 

The fifth-generation languages 
will be Al-inspired natural-language 
systems that characteristically han¬ 
dle a variety of grammatical/non- 
grammatical constructions, infer 
from user inquiry where data will be 
found in a database, and execute 
necessary manipulations, proce¬ 
dures, and formatting. 

These systems are yet to be 
made generally available, but you 
can see the beginnings in such Ai lan¬ 
guages as Prolog and lisp. 

In 1969 J. E. Sammet con¬ 
cluded her seminal book on the 
history of programming languages 
(Programming Languages: History 
and Fundamentals) with the predic¬ 
tion that future developments would 
either be theory-oriented or user- 
oriented. The goal of a theory- 
oriented approach is to give the sys¬ 
tem a complete characterization of 
all objectives to be achieved and let 


it design the program accordingly. 
Many fourth-generation languages 
take this approach. 

The goal of a user-oriented 
approach is to implement a natural 
language to allow the system to re¬ 
spond to the specific idiosyncrasies 
of each user’s needs. Sixteen years 
later, the debate still continues, 
and both approaches are still in 
progress. □ 


David Spencer is technical publications 
manager at Oregon Software Inc., Port¬ 
land, Ore. After teaching English for 10 
years, he has written software documen¬ 
tation over the last five years for Sperry 
Univac and Oregon Software. His inter¬ 
est in programming languages stems from 
his graduate days at USC, where he stud¬ 
ied rhetoric, linguistics, and literature. 
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GLOSSARY 


Declarative languages. A program consists of a set of rules 
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Procedural languages. Program consists of flow-control con¬ 
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Rule-based language. Same as declarative language. 

Functional programming. Program consists of a set of compu¬ 
tational instructions. 
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operations; the combination (called an object) is activated by 
commands to do things. 

Query language. A query language such as SQL is used to 
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Expert system. Stores knowledge that a human expert might 
give in response to questions. 

Knowledge system. Same as an expert system. 
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with experience in leading com¬ 
puter technologies. CALL US 
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F rom the first assemblers and 
compilers to today’s icon- 
based operating systems and 
mmmmmm windows, software has be¬ 
come progressively easier to use. 
Now, with fourth-generation lan¬ 
guages (those that can understand 
English-like commands) finally com¬ 
ing to market, truly intuitive software 
may at last be on the way. After all, 
what could be easier than program¬ 
ming and working in plain English? 

Unfortunately, that ultimate ca¬ 
pability isn’t available yet, although 
some new products come close. 
Many popular database management 
system (DBMS) packages have begun 
to incorporate fourth-generation lan¬ 
guages, and new types of software 
such as expert systems use similar 
capabilities. 

In this article, I’ll be looking at 
the history of this field and at some of 


UNDERSTANDING 

FOURTH 

GENERATION 

LANGUAGES 

At last. 

With fourth-generation 
languages finally 
coming to market, 
truly intuitive software 
may be on the way. 

BYDOUGMAHUGH 


the commercial products that have 
come out of it. Not every application 
can benefit from a fourth-generation 
language, so I’ll also consider how 
you can decide whether it’s appropri¬ 
ate for you. Finally, I’ll take a look at 
the future of this interesting class of 
software products. 

Fourth-generation languages 
are a commercial application of the 
field of research known as the natural 
language (nl) problem. Simply 
stated, the NL problem is the task of 
developing a computer program that 
can understand written or spoken 
English commands. The fields of 
computer science, linguistics, and 
cognitive psychology have all played 
a part in attempts to solve this 
problem. 

Fourth-generation languages 
vary widely in their capabilities and 
applications. They range from simple 
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y languages that can recognize a 
synonyms to powerful applica- 
i generators that can understand 
..plicated sentence structures, 

;i look spelling errors, resolve am- 
ous requests, and learn new 
Is and procedures. 

The most common use of 
f h-generation languages to date 
been in DBMSs; some products of- 
a fourth-generation language for 
: "active queries, some for devel- 
irg applications, and many offer 
i. Another popular application of 
th-generation languages is in ex- 
. systems, which help users solve 
iblems in specific domains, much 
an expert would, by responding 
requests in English and by asking 
vant questions when more infor- 
on is needed. 

Almost every major software 
devleloper is working on one of these 
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products. Many vendors believe they 
will find a big market with managers 
and executives who have always had 
to rely on data-processing personnel 
to get them the information they 
need. With a fourth-generation lan¬ 
guage query system, managers 
themselves could find the information 
they need quickly and easily. 

A more certain market is in small 
companies that cannot afford to hire 
programming staff to develop the 
custom applications. Traditionally 
these firms have had to get by with 
existing software or hire expensive 
contract programmers. Using a 
fourth-generation programming lan¬ 
guage, however, personnel from 
marketing, accounting, or production 
could generate the applications they 
need without professional help. 
Some analysts have even predicted 
that steady improvement of fourth- 


generation languages will eliminate 
the need for application program¬ 
mers altogether. 

A HISTORY OF NATURAL 
LANGUAGE SOFTWARE 

A look at the history of natural lan¬ 
guage (nl) research, however, 
shows that these predictions should 
be taken with a grain of salt. Progress 
on the natural language problem has 
been steady but slow. In the late 
1950s, many researchers believed 
that the development of computer 
programs that could understand En¬ 
glish was only a few years away. 
Now, 25 years later, the most opti¬ 
mistic researchers believe that we 
are still a few years away from any 
general solution. 

Most of the early work on natu¬ 
ral language software was done by 
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ISO is designed to the International Standards Organization 
ISO 6429 guidelines. 


When you’re 
ready for the 
brilliance of color, 
we’ll be there. 

Now you can have the beauty and 
precision of color graphics for business, 
engineering and scientific applications- 
at much less cost than ever before! 
Qumes new QVT 511GX™ terminal 
provides flicker-free, non-interlaced 
raster scan graphics, with a selection of 
up to eight colors from a palette of 64- 
The QVT 511GX is fully compatible 
with the Tektronix 4105 and accepts all 
of its software, including PLOT 10 
packages. It can also be used in Tektronix 
4010,4100 and 4110 series environments, 
and works beautifully with the Tektronix 
4695 color graphics copier. What’s more, 
it conforms to both ANSI X3.64 and 
ISO 642.9 protocols for text editing. 

A mouse device, capacitive keyboard, 
and advanced ergonomic design are 
all standard. 

The QVT 511GX measures up to 
Qumes exceptional standards for per¬ 
formance, quality control, and reliability. 
And it’s backed by our experience and 
resources as an ITT company. So what¬ 
ever your applications, we’ll be there with 
a dazzling display of technical support. 

For full details on the new QVT 
511GX and Qumes other graphics and 
alphanumeric terminals, or our full 
line of daisywheel printers and disk drives 
call (800) 223-2479. Or write Qume 
Corporation, 2350 Qume Drive, San Jose, 
CA 95131. 
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artificial intelligence (ai) research 
-nunity, largely in response to 
ition of the Turing Test as a mea- 
of machine intelligence. The 
ing Test was proposed by Alan 
.ing in 1950 as a way of determin- 
whether machines can think. In it, 
i, arson presents questions to two 
seen entities, one of which is an- 
lar human being and the other a 
j ;hine. If the person asking the 
ie[stions cannot determine which of 
two is the machine, then the ma¬ 
le has passed the Turing Test, 
viously, natural language capabil- 
is a prerequisite to passing the 
dng Test. 

The first program to give a con- 
i:ing appearance of understanding 
itural language was developed in 
>9. Known as the Conversation 
chine, it could provide seemingly 
levant responses to comments 
iut the weather and could answer 
iple questions. However, because 
meaning of the dialogue was not 
iDortant, the Conversation Ma¬ 
le’s natural language capability 
merely an illusion. 

The first program that could be 
to understand natural language 
quests was Sad Sam, developed in 
)63 by Robert Lindsay. You could 
ill this program the relationships be- 
veen persons in your family, and the 
iragram would then answer ques- 
ns about those relationships. You 
ln’t have to base the questions on 
larticular facts that you had already 
..ven the program because Sad Sam 
inured out answers by deduction, 
iased on what it had been told. This 
/is also the first natural language 
irogram to incorporate extensibility, 
leaning that it could acquire knowl- 
idge and grow in capability. 

Another program developed in 
$63, Baseball, was the first to hint 
the bright future of fourth-genera- 
m languages for database queries. 


hin 

as 


Baseball was developed at Lincoln 
Laboratories under the direction of 
B.F. Green, and it answered En- 
glish-like questions about the pre¬ 
vious year’s American League 
games. A small database stored all 
the information, and the program 
translated questions into appropriate 
searches. 

After these early efforts, natural 
language programs became popular. 
Although most were simple illusions, 
some were significant break¬ 
throughs. Joseph Weizenbaum’s 
Eliza program, developed in 1966, 
was the first programmable natural 
language product because you could 
give it a script that would make it par¬ 
ody any type of behavior. This pro¬ 
gram, using a script for a Rogerian 
psychotherapist, is available for mi¬ 
crocomputers and is still popular 
today. 

Another significant develop¬ 
ment was Terry Winograd’s shrdlu 
program. Completed in 1970 at mit’s 
Artificial Intelligence Laboratory, 
shrdlu was a fully functional fourth- 
generation language that responded 
to requests about a mythical world of 
colored blocks and pyramids. The 
program could manipulate its model 
of the world by stacking objects on 
top of one another and moving them 
around at the user’s request. It could 
also answer questions about the rel¬ 
ative positions of objects . 

shrdlu’s two most impressive 
features, however, were the ability 
to understand ambiguous requests 
by referring to earlier requests and 
the ability to answer questions about 
its reasoning (such as “Why did you 
put the green cube there?”). These 
capabilities are now included in many 
commercially available fourth-gener¬ 
ation languages. 

Specialized natural language 
products for mainframes started to 
appear on the market in the late 
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FORTRAN 

The SVS FORTRAN-77 
language is now available on 
an expanded family of CPUs. It 
fully supports: 

• Full Ansi Standard 

MC68000 

• GSA Certifiable 

• Many Language Extensions 
derived from our large 
user community 

• Symbolic Debugger 

NS32000 

• Optimizing Code 

Generation 

• High Speed Compilation 

• Very Large Applications 
• Integrated Hardware 

Floating 
Point Interfaces: 
MC68881, SKY, NS32081, 
and Custom 

MC68020 

• Complete User 
Documentation 

• Available since 1981 

SVS has been a major 
OEM supplier of compilers 
since 1979. 

For further information about 
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DEFINING FOURTH-GENERATION JARGON 


When you consider that sim¬ 
pler communication is the goal 
driving fourth-generation soft¬ 
ware development, it is a little 
ironic that the field has devel¬ 
oped a confusing language of its 
own. The most common terms 
used to describe fourth-gener¬ 
ation software are defined 
below. 

Context: Natural language 
(NL) programs are usually clas¬ 
sified as either context-sensi¬ 
tive or context-free. (Techni¬ 
cally, these terms refer to the 
grammar used.) Context-sensi¬ 
tive means that the interpreta¬ 
tion of words is affected by their 
context, while context-free 
means that a word has only one 
possible interpretation, no 
matter how it is used. English 
is obviously context-sensitive; 
the word run, for example, has 
more than 40 possible 
interpretations. 

Expert System: A program 
that has access to the facts and 
reasoning processes needed to 
solve problems in a particular 
field. Users consult expert sys¬ 
tems in the same way they 
would consult a human expert; 
the expert system analyzes the 
problem and either gives an 
analysis or asks for more 
information. 

Extensibility: The ability 
of a fourth-generation language 
to acquire new knowledge 
about the data it works with. 
Syntactic extensibility is the 
ability to learn new definitions; 
semantic extensibility is the 
ability to learn new relation¬ 
ships, or semantic links. 

Fourth-Generation Com¬ 
puter: Any computer based on 
VLSI (very large scale integra¬ 
tion) technology. This term has 
no direct connection to fourth- 
generation software (see be¬ 
low), so its use can be mislead¬ 
ing. The first five generations 


of computer hardware are vac¬ 
uum-tube technology, transis¬ 
tor technology, integrated- 
circuit technology, vlsi tech¬ 
nology, and kips (knowledge in¬ 
formation processing systems). 
There is currently a great deal 
of debate about the differences 
between fourth- and fifth-gen¬ 
eration computers. 

Fourth-Generation Lan¬ 
guage: A programming lan¬ 
guage that takes English-like 
sentences as input and per¬ 
forms the tasks that these sen¬ 
tences describe. Fourth-gener¬ 
ation languages are not as 
much like written English as 
many users expect them to be, 
but they are powerful and easy 
to use. The most important cri¬ 
terion of a fourth-generation 
language is that it provides 
more automation of features 
than third-generation lan¬ 
guages such as FORTRAN, COBOL, 
and C. The first three genera¬ 
tions of programming lan¬ 
guages are machine languages, 
low-level compiled or assem¬ 
bled languages, and high-level 
languages such as fortran and 

COBOL. 

Natural Language Soft¬ 
ware: Programs that can under¬ 
stand inputs given in standard 
written English. Although no 
general-purpose natural lan¬ 
guage program has been devel¬ 
oped yet, many programs can 
understand English sentences 
of a certain type or those that 
are limited to a specific topic. 

Nonprocedural Language: 
A programming language that 
allows the programmer to state 
goals to be achieved, rather 
than the specific procedures 
necessary to accomplish them. 
In contrast, procedural lan¬ 
guages such as C and Pascal al¬ 
low the programmer to specify 
how the program will run, as 
well as what it will do.— D.M. 


1970s, 20 years after the ai commu¬ 
nity began to tackle the problem. The 
first commercially successful nl 
product was Intellect, from Artificial 
Intelligence Corp. It ran on IBM and 
compatible mainframes and inter¬ 
faced with many popular DBMSs. 

Savvy, from Excalibur Technol¬ 
ogies, was the first nl product for mi¬ 
cros. It used a limited pattern-match¬ 
ing approach but managed to fit into a 
mere 4K bytes of memory. Savvy 
gave users the capability to modify 
data as well as display it, so it was 
both a query language and a program¬ 
ming language. 

In late 1984, Microrim released 
Clout, a natural language interface 
that works with several popular mi¬ 
crocomputer DBMS products. Clout’s 
capabilities are limited, but it is a sig¬ 
nificant product because many devel¬ 
opers had felt that true nl capability 
required too much memory and pro¬ 
cessing power to ever be success¬ 
fully implemented on micros. 

MODERN FOURTH- 

GENERATION 

LANGUAGES 

The Unix system has been a late ben¬ 
eficiary of natural language research. 
However, over the past year many 
Unix system software vendors have 
added fourth-generation languages to 
their DBMS products. (The acronym 
that seems to be catching on for this 
type of product is DBMS + 4gl). Data 
General, Prime, Micro Data Base 
Systems, Hewlett-Packard, sir, Re¬ 
lational Database Systems, and Data 
Language Corp. have all added some 
type of fourth-generation language 
capability to their DBMSs, and many 
other Unix system software devel¬ 
opers are doing the same. 

As I mentioned earlier, the two 
most common uses for fourth-gener- 
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Reduced software costs 
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• All code reentrant 

• Dynamic memory allocation without fixed partitions 
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• Large set of utilities 
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• Pipes, forks, semaphores, and shared data segments 

Other CMI Series/1 software 

• RM/COBOL™ 

• UNIFY™ database management system 

• ViewComp™ spreadsheet 
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ation languages are query languages 
and application generators. These 
applications are ideally suited to 
fourth-generation languages because 
the limited vocabulary (terms rele¬ 
vant to a specific database) simplifies 
the interpretation process. 

Although the vocabulary of 
fourth-generation languages may be 
limited, advertising and public rela¬ 
tions copywriters have come up with 
an unlimited number of adjectives to 
describe them. I’ll avoid most of the 
jargon here, but one distinction de¬ 
serves special attention: procedural 
versus nonprocedural fourth-gener¬ 
ation languages. 

In the past, fourth-generation 
languages were considered nonpro¬ 
cedural by definition. Supposedly, 
the whole purpose of a fourth-gener¬ 
ation language was to let users de¬ 
scribe what they wanted to do and not 
how it should be done. After some 
real-world experience with nonpro¬ 
cedural languages, however, this ap¬ 
proach was clearly imposing limita¬ 
tions on programmers; many types of 
tasks can be specified only in a pro¬ 
cedural language. 

Consequently, developers be¬ 
gan to use the term procedural 
fourth-generation language—a 
seeming contradiction in terms—for 
languages that offer fourth-genera¬ 
tion language ease of use while allow¬ 
ing users to specify procedures if 
necessary. This type of language is 
so popular that the working definition 
of fourth-generation language has 
changed to allow both procedural and 
nonprocedural languages. 

SIR/dbms is one product that of¬ 
fers a solution to the procedural-ver- 
sus-nonprocedural problem, sir’s 
nonprocedural fourth-generation lan¬ 
guage generates a short program (in 
a procedural language) for each com¬ 
mand. You can then modify this pro¬ 
gram if you need more control than 
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the nonprocedural fourth-generation 
language provides. 


TWO TYPES OF 
EXTENSIBILITY 

Another important concept is men 
sibility: the ability of the system to 
acquire new knowledge. Modern 
fourth-generation languages have 
two types of extensibility: syntactic 
and semantic. 

Syntactic extensibility allows a 
user to add new definitions to the data 
dictionary. Ideally, the fourth-gener¬ 
ation language should be able to do 
this whenever a user enters an un¬ 
recognized phrase; this way, users 
can stick with the terminology 
they’re used to, and the system will 
learn new terms as they are needed. 

With Microrim’s Clout2, for ex¬ 
ample, the system displays an unrec¬ 
ognized phrase and then asks the 
user to “Please enter a synonym or 
change spelling. ” If the user enters a 
synonym made up of recognized 
phrases—that is, a new definition— 
the system stores the definition for 
future reference. 

The other type of extensibility, 
semantic extensibility , allows users to 
define new relationships and new 
processes. For example, you might 
specify that “customers have credit 
limits.” This is known as a semantic 
link, and it lets the fourth-generation 
language know that when you say 
“Who is over their credit limits?” 
you’re asking for a list of customers. 
This semantic information, combined 
with the data dictionary, is the “real- 
world knowledge” that the fourth- 
generation language calls upon . 

A fourth-generation language 
can also use semantic links to 
meaningless queries and errors 
McGuire, vice president of market¬ 
ing at Data Language Corp. (dlc), 
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points out that “a fourth-generation 
language can recognize errors that a 
third-generation language like COBOL 
or basic can’t, such as inappropriate 
use of a certain record type.” dlc’s 
Progress DBMS provides this type of 
intelligent error checking in its 
fourth-generation language. 

Another way to resolve ambi¬ 
guities is to refer to the user’s pre¬ 
vious commands. This is called accu¬ 
mulating context , and it’s similar to 
the way people figure out what is 
being referred to in everyday conver¬ 
sation. If you say “I saw Joe today” 
and then say ‘‘He wants you to call 
him,” most people will realize that 
“He” refers to Joe. Likewise, if you 


ask a fourth-generation language to 
“list the products with sales less than 
1000” and then type “Which of those 
have sales less than last month?” ac¬ 
cumulated context will make the 
fourth-generation language assume 
you mean “Which products with sales 
less than 1000 have sales less than 
last month?” 

Ironically, one problem with 
fourth-generation languages is the 
large amount of power they provide. 
Through implied calculations and 
searches, a user can make a simple 
request that might require a great 
amount of machine time. For exam¬ 
ple, a user may ask for the top three 
revenue-producing products in this 


year’s product line. If revenue to date 
is a stored parameter, this is a simple 
request; if it isn’t, revenues may have 
to be calculated for every product in 
the database in order to find the top 
three, and each of those revenue cal¬ 
culations may in turn require search¬ 
ing through all the orders for that 
product so far this year. 

The more sophisticated fourth- 
generation languages check for such 
cases and let you know that the re¬ 
quest will take a long time. The pro¬ 
gram Intellect, for example, tells you 
that “You have just made a very ex¬ 
pensive request in terms of CPU time. 
Do you wish to make this a batch 
request?” 


THE NATURAL LANGUAGE PROBLEM 


Although we take it for 
granted, the process of under¬ 
standing a sentence is not a 
simple one. Furthermore, the 
information needed to under¬ 
stand a sentence is not always 
contained in the sentence it¬ 
self: You need to know its con¬ 
text as well as general infor¬ 
mation about what makes 
sense in the real world. For ex¬ 
ample, most people would in¬ 
terpret the sentence “Who 
makes the most money?” as a 
question about earnings be¬ 
cause the other meaning (coun¬ 
terfeiting) is not common. 

It would be impossible to 
store all of the general infor¬ 
mation necessary to under¬ 
stand any possible sentence, so 
fourth-generation languages 
all work in a limited domain. 
This keeps the amount of nec¬ 
essary “background informa¬ 
tion” manageable. In a data¬ 
base query language, for 
example, the fourth-generation 
language typically has access 
to the terms in the data dictio¬ 
nary and the logical relation¬ 
ships between them, along 
with some general information 


about what types of operations 
are allowed on each type of re¬ 
cord or variable. 

Along with this informa¬ 
tion, a fourth-generation lan¬ 
guage has some general rules 
for determining meaning. Al¬ 


though fourth- generation lan¬ 
guages use many different ap¬ 
proaches, most of them go 
through a process that can be 
broken down into three steps: 
syntactic analysis, semantic 
analysis, and deduction. 


WHO MAKES THE MOST MONEY? 


sentence 


WHO 


| pronoun 



MAKES THE MOST MONEY 


verb phrase 


MAKES 


verb 



MOST 


modifier 


MONEY 


noun 


FIGURE 1: SYNTACTIC ANALYSIS OF A SENTENCE BY PARSING 
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Another potential problem with 
fourth-generation languages is the 
complete lack of direction they pro¬ 
vide. Menu-driven systems show 
new users what the system is capable 
of, but a fourth-generation language 
provides no hints about where to 
start. Texas Instruments, a leader in 
natural language research, has come 
up with a combination menu-driven/ 
natural language approach that ad¬ 
dresses this problem. 

CHOOSING A FOURTH- 
GENERATION LANGUAGE 

Can your application benefit from a 
fourth-generation language? This is a 
question only you can answer, but 
here are a few general guidelines to 
follow. 

If you're looking for a 
DBMS + 4gl, consider how many 
users the system will have and how 
often they will be using it. If your ap¬ 
plication will have only a few users 
and if all will be using the system 
daily, a fourth-generation language 
may not be worthwhile. A fourth- 
generation language will be more 
useful if you need to give occasional 
users and first-time users easy ac¬ 
cess to the system. 

If you’re a developer, the choice 
of a fourth-generation language will 
be determined by the system you’re 
working with. Because almost all 
fourth-generation languages have 
been designed for specific DBMSs, 
your choice will be limited; in fact, 
you may not have any choice at all. 
Although several fourth-generation 
query languages (such as Savvy, 
Clout2, and Natural Link) have the 
ability to work with more than one 
DBMS, fourth-generation program¬ 
ming languages do not yet offer this 
capability. 

If you have decided that a fourth- 


generation language can help your 
application, there are many features 
to consider. 

First, how large is the data dic¬ 
tionary? Can users add new defini¬ 
tions? Is there a limit to the number 
of user additions? 

Second, does it provide seman¬ 
tic extensibility? Can the end-user do 
this? 

Third, does it use accumulated 
context? Can users see the current 
context? 

Fourth, does it provide a proce¬ 
dural language? Can you combine 
procedural and nonprocedural lan¬ 
guages for a specific problem? 

And finally, what are the hard¬ 
ware and software requirements? 
Does the fourth-generation language 
interface directly with your existing 
data or provide a utility that will trans¬ 
late your data to the format it 
requires? 

In addition to these features, 
you’ll want to check how the language 
handles errors in syntax and logic. 
Does it recognize misspelled words? 
Does the fourth-generation language 
check for inappropriate use of a data 
type? 

Another feature to look at is the 
installation process. Some fourth- 
generation languages require that 
you specify plural definitions explic¬ 
itly in the data dictionary; in other 
words, you must define companies to 
be the same as company. More ad¬ 
vanced fourth-generation languages 
have this capability built in and will 
recognize the plural form of a defined 
data type for what it is. In general, 
the installation process should be as 
automated as the fourth-generation 
language itself. 

Because you cannot always get 
a demonstration of software before 
you buy it, you may have to make a 
decision based on printed materials 
or conversations with salespeople. In 
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this case, be wary of the jargon used 
in ads and marketing literature for 
natural language products. Pay more 
attention to specific examples than 
vague descriptions. And, perhaps 
most importantly, if an example uses 
an unusual sentence construction, 
assume that this construction is re¬ 
quired. If a simpler or more obvious 
example were possible, the ad prob¬ 
ably would have used it. 

THE FUTURE 

It remains to be seen whether fourth- 
generation languages will take the 
software industry by storm. For one 
thing, enough products aren’t yet 
available to see how users will react. 
In addition, heavy advertising of nat¬ 
ural language “vaporware” and mis¬ 
leading ads have jaded many potential 
buyers. 

Despite these public relations 
problems, however, the merits of 
natural language software for DBMS 
query are too great to be ignored. 
Considering that nearly every major 
DBMS has a fourth-generation query 
language or has plans for one, it 
seems likely that natural language ca¬ 
pability will soon replace IBM’s SQL as 
the de facto standard query language. 
This will give corporate information 
centers the ability to take advantage 
of new DBMS technology without re¬ 
training end-users. 

The future of fourth-generation 
languages for programming work is 
not as clear. It is already obvious that 
English-language capability in a 
fourth-generation language will not 
be of great help to programmers. 
Granted, such a language would give 
nonprogrammers the ability to write 
simple programs, but designing pow¬ 
erful and innovative applications with 
that language would be no easier than 
describing such applications in En¬ 
glish. And—as any documentation 


writer can attest—it sometimes 
takes many pages of English to de¬ 
scribe the operation of a single page 
of code. 

Of course, computer languages 
exist (Algol-68, for example) that are 
better suited than English to the task 
of describing programs, and future 
fourth-generation languages for pro¬ 
gramming will probably mimic those 
languages. This will increase pro¬ 
grammer productivity, but even 
greater gains may be made through 
the use of icon-based systems, as in 
the Xerox Star, Apple Macintosh, 
and the AT&T Unix PC. 

And what of the future of fourth- 
generation languages under the Unix 
system? One possibility is the 
development of a fourth-generation 
language front-end for the Unix sys¬ 
tem that would generate shell scripts 
to carry out specified actions. Users 
could build their own data dictionaries 
and then ask for results by using En¬ 
glish-like queries. Such a shell could 
easily be ported to any Unix system 
and would provide the Unix system’s 
full power to inexperienced users. 

If this sounds like an over¬ 
whelmed Unix novice’s secret fan¬ 
tasy, bear in mind that two products 
already on the market—SI and the 
Unix Consultant—come close to this 
capability, and others are likely to fol¬ 
low. Continued improvement of 
products such as these will make 
working with the Unix system as en¬ 
joyable for beginners as it is for 
experts. □ 


Doug Mahugh is an independent program¬ 
mer and writer based in Chicago. The for¬ 
mer editor of Joystik Magazine, Mr. Ma¬ 
hugh has also worked as a programmer for 
the Boeing Company and as a writer and 
editor of books on microcoynputers. 
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PROLOG AS A 
UNIX SYSTEM 
TOOL 

As Prolog interpreters and compilers become faster and 
as libraries of code become available, Prolog will become 
a worthy competitor to C. 


BY JOHN MALPAS 


T he logic programming move¬ 
ment (along with the most 
widespread logic program¬ 
ming language, Prolog) is 
beginning to attract attention from 
people on all levels of the computer 
industry. Bom and nurtured in Euro¬ 
pean universities, Prolog is now 
being used by several government 
and business institutions in Europe 
and the United States. 

Some of the most enthusiastic 
support for the new technology can 
be found in Japan, both on the part of 
researchers in the Fifth-Generation 
project, in particular, and in the Japa¬ 
nese software industry, in general. 
For example, officials at ash Interna¬ 
tional, a Tokyo software-develop¬ 
ment company, expect Prolog to be¬ 
come a standard language (along with 
basic, FORTRAN, and C) that all pro¬ 
grammers will learn. 

To listen to its advocates, logic 
programming has great theoretical 
promise. The technology is based on 
using symbolic logic (as expressed in 
so-called Horn clause form) as a pro¬ 
gramming language. Symbolic logic 
was originally developed as a univer¬ 


sal language for expressing situations 
and problems. Logic programming is 
a subset of logic, but it is equally 
broad in scope. It can serve as a uni¬ 
versal language for expressing other 
paradigms of computer science, in¬ 
cluding relational database theory, 
software engineering, parsing the¬ 
ory, and artificial intelligence (ai) 
knowledge representation. 

What makes logic programming 
unique is its declarative semantics. A 
logic program is a set of rules that de¬ 
clare the conditions under which 
some relationship is thought to exist. 
Unlike procedural languages, logic 
programming is not based on the de¬ 
structive assignment statement. 
This means that once a variable has 
assumed a value, the programmer 
cannot arbitrarily change it. 

Because of this, a logic program 
exists on a higher level than the pro¬ 
cess it is modeling and is said to de¬ 
scribe the process. By way of con¬ 
trast, most procedural language 
programs exist on the same level as 
the process they are modeling, and 
thus they can only simulate the 
process. 
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Finally, logic programming al¬ 
lows the co-existence of a meta¬ 
language with the object language 
(Prolog itself). Such ability gives logic 
programming great extensibility be¬ 
cause it allows a programmer to 
change the behavior of the inter¬ 
preter without rewriting it. 

If this is logic programming’s 
theoretical promise, what of its real¬ 
ity? As a Unix system and C contract 
programmer, I had occasion to find 
out last summer, when I wrote a soft¬ 
ware testing application using Prolog 
for a major financial institution. The 
experience confirmed many of the 
strengths of Prolog but also revealed 
some features that currently make it 
an immature application language. 
Fortunately, the version of Prolog I 
used for this project is well integrated 
with the Unix system. The experi¬ 
ence leads me to believe that Prolog 
may have a bright future as a Unix 
system tool. 


THE PRACTICE OF 
PROLOG 

What is immediately attractive about 
Prolog as a practical language is its 
inherent discipline: The number of 
ways to express an idea is limited. As 
a result, programmers tend to solve 
the same problem in the same way. 
Prolog has few lexicographical sym¬ 
bols, so the code is easy to read. Be¬ 
cause of Prolog’s high level, you can 
express in a single page a routine that 
might require 10 or 20 pages of C. 
This bodes well for maintenance. 

Prolog is similar to several high- 
level declarative languages found in 
the Unix system, such as yacc, 
make, and tbl. For example, both 
yacc and Prolog are rule-based 
languages. Whereas you can usually 
use yacc rules to describe a gram¬ 
mar, you can use Prolog rules to 


to describe anything. A rule in either 
language consists of a conclusion fol¬ 
lowed by multiple conditions. 

One difference between the two 
languages is that yacc uses a for¬ 
ward-chaining resolution strategy 
suitable for implementing bottom-up 
parsers, while Prolog uses a back¬ 
ward-chaining strategy similar to that 
of a top-down parser. 

Another major difference is that 
yacc allows C language procedures 
to be attached to rules. As a result, 
each yacc rule has side effects that 
are unexplainable according to the 
semantics of y a c c itself. In Prolog, 

I was able to rip out 
large sections of code 
and fix or replace them 
in a day or two. 

on the other hand, the only way to 
express anything is with a rule. 
There are no attached procedures, 
so the language has precise and com¬ 
pletely uniform semantics. 

When I first started using 
Prolog, it seemed like a good idea to 
be able to mix C code with the rule 
base in a manner similar to y a c c. I 
had the impression that C would per¬ 
form certain jobs such as screen han¬ 
dling more appropriately. But Ken 
Bowen, a professor of logic program¬ 
ming at Syracuse University, indi¬ 
cated that Prolog is a complete pro¬ 
gramming language that can stand on 
its own. 

My own experience proves this 
point of view to be correct because 
Prolog turned out to be adept even at 
low-level tasks such as screen han¬ 
dling. Furthermore, a Prolog pro¬ 
gram is easier to read than a y a c c 
program precisely because there are 
no attached procedures. 


PATTERN MATCHING 

Prolog has pattern-matching abilities 
that in some ways exceed those of 
Unix system utilities such as g r e p 
or 5 e d. One of my first projects with 
the language was to write a 5 e d-like 
text-filtering program that performs 
a set of textual transformations on a 
file. But where sed can match pat¬ 
terns only on the lexical level (that is, 
patterns involving characters and 
repetitions of characters), my Prolog 
program can handle both lexical and 
word-level patterns. 

An example word-level pattern 
specification is the following: “Find 
any number of words, beginning with 
the word Charles and ending with a 
word containing the string decid” 
This will locate a span of words such 
as “Charles, who just returned from 
India, decided ...” Because this 
Prolog program operates on a sen¬ 
tence at a time instead of a line at time 
(as do g r e p and 5 e d), it also finds 
word patterns that cross over line 
boundaries. 

At the beginning of last summer, 
I was charged with doing human fac¬ 
tors testing of pc software for a de¬ 
partment in a large financial institu¬ 
tion. The typical test situation 
involved sitting subjects down in 
front of a PC with the relevant soft¬ 
ware running and asking them to per¬ 
form a series of tasks. The subjects 
were videotaped to determine if cer¬ 
tain screens made them nervous, and 
a file was generated containing every 
keystroke they made, along with 
time, error conditions, and so on. 

Additional complications arose 
because we frequently added new 
tasks and were always changing 
them. Furthermore, subjects never 
seemed to go through the tasks in the 
prescribed order. Nontechnical per¬ 
sonnel needed to be able to add new 
tasks to the system’s repertoire at 
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describe anything. A rule in either 
language consists of a conclusion fol¬ 
lowed by multiple conditions. 

The problem was to analyze the 
output of the tests, determine which 
task the subject was attempting, and 
then produce statistics about tasks 
completed, number of backspaces, 
number of erroneous menu paths, 
and so on. Analysts could then tell 
from the statistics which instructional 
wording was bad or which screens 
were incomprehensible. 

Fortunately for me, the director 
of this project had a predilection for 
doing the test file analysis on a Unix 
system. We decided to build a proto¬ 
type in a w k, a language he favored 
because it is of a higher level than C 
and therefore easier to maintain. 

The awk prototype worked 
well for a file containing a single 
known task. We implemented an 
awk code-writing scheme that ena¬ 
bled an analyst to add a new task to 
the system simply by going through 
the task once on the pc, and then us¬ 
ing a “build” program on the resulting 
file. 

The aspect of the problem that 
seemed beyond awk’s reach was 
discovering which task in a file that 
contained multiple tasks the user was 
attempting. Because this is essen¬ 
tially a parsing problem, I suggested 
either yacc or Prolog. After long 
deliberations, we decided to go with 
Prolog. Like awk, Prolog is usually 
an interpreted language. This gives it 
an advantage over yacc for strate¬ 
gies involving automatic code 
generation. 

THE SYSTEM 

The final system was made up of four 
components: a two-stage lexical ana¬ 
lyzer, a parser that also counted er¬ 
rors, a program that automatically 
added new tasks to the parser, and a 


report generator. In the initial ver¬ 
sion, all four components were part 
of one large Prolog program. 

Although we were developing 
the system on a Convergent Tech¬ 
nologies MiniFrame with virtual 
memory, input data files above a cer¬ 
tain size caused the program to run 
out of memory. (This is where Prolog 
gets its reputation for being a mem¬ 
ory hog.) The bottleneck turned out 
to be the lexical analyzer. We needed 
an alternative strategy if the system 
was ever going to be able to handle 
files that had more than about 700 
lines. 

The answer we came up with 
was to separate the components into 
three Prolog programs, with the out- 

Prolog’s biggest current 
disadvantage is that it 
requires large amounts 
of memory and CPU 
resources. 

put of the lexical analyzer piped into 
the input of the parser, and the output 
of the parser piped into the input of 
the report generator. Each compo¬ 
nent thus acted as a code generator 
for the next one. 

For instance, the lexical ana¬ 
lyzer asserted a set of facts (contain¬ 
ing the input data) into the database 
of the parser and then caused the par¬ 
ser to begin executing by sending it a 
query. The parser looked up the data 
asserted by the lexical analyzer, 
parsed it, and then asserted a set of 
facts containing its output into the da¬ 
tabase of the report generator. Using 
this strategy, the lexical analyzer 
could read the input file in discrete, 
manageable segments, and therefore 
there was no danger of running out of 
memory. 


A shell script controlled the 
whole process. It sent a query to the 
first Prolog program to start it up, 
and then c a t ed the input data file to 
it. This shell script could also turn on 
tracing for parts of the Prolog pro¬ 
gram that were being debugged. 

The version of Prolog we used 
did not have a particularly rich library 
of predicates for data manipulation. 
To produce respectable-looking re¬ 
ports, we had to write such basic 
items as a t o i (convert a string of 
digits to an integer and vice versa) 
and p r i n t f (formatted print 
statement). This lack must be caused 
by the fact that many of the other re¬ 
searchers experimenting with Prolog 
are not concentrating on report for¬ 
mats. In fact, both predicates were 
straightforward to implement. 


CONCLUSION 

So far, the people for whom I built the 
system seem to be happy with it. The 
aspect of Prolog that most impressed 
me in this project was ease of main¬ 
tenance. During the development 
process, I frequently brought a new 
version of the system to the cus¬ 
tomer, demonstrated it, and then lis¬ 
tened to feedback about what was 
wrong with it or what new features I 
needed to add. I was able to rip out 
large sections of code and fix or re¬ 
place them in a day or two. To per¬ 
form such major surgery on an equiv¬ 
alent C program would have taken at 
least a week. 

Prolog’s biggest current disad¬ 
vantage is that it requires large 
amounts of memory and CPU re¬ 
sources. When evaluating the cost- 
effectiveness of doing an application 
in Prolog as opposed to a leaner tech¬ 
nology, consider the trade-off: pro¬ 
grammer productivity versus effi¬ 
cient machine utilization. Personally, 
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I will always choose programmer 
productivity at the expense of ma¬ 
chine efficiency, having learned the 
hard way that no specification is 
immutable. 

It should be clear from this arti¬ 
cle that Prolog thrives in the Unix 
system environment. What may not 
be as clear is that Prolog has a great 
deal to offer the Unix system. For ex¬ 
ample, you can use it when the limi¬ 
tations of awk or sed become 
unworkable. 

Input data files above a 
certain size caused the 
program to run out of 
memory; this is where 
Prolog gets its 
reputation for being a 
memory hog. 

Prolog is also a highly produc¬ 
tive application language in its own 
right. As Prolog interpreters and 
compilers become faster and as li¬ 
braries of Prolog code become avail¬ 
able, we can look forward to a time 
when Prolog will be a viable and wor¬ 
thy competitor to C and other high- 
level languages for many types of 
applications. □ 


John Malpas, a consultant in New York, 
teaches a Prolog programming workshop 
at Structured Methods Inc. He is the au¬ 
thor of a book entitled Introduction to 
Prolog and its Applications, to be pub¬ 
lished this fall by Prentice-Hall. 
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I MODITT.A-2 

Lknocks on the door 

Because of its special features—in particular ; its 
modular structure — Modula-2 could become a leading 
programming language by the end of the eighties . 


BY GIACOMO MARINI 


T he C language has been in¬ 
tegrated with the Unix sys¬ 
tem for many years, but this 
historical partnership is an 
insufficient reason to preserve C as 
the primary language for the Unix 
system. Although the basic capabili¬ 
ties of the Unix system, as well as 
the utilities and applications available 
with it, have evolved substantially 
since the Unix system’s inception, C 
has changed minimally during this 
time. The dual popularity of the Unix 
system and C stems from attributes 
of the Unix system, not from special 
features of C. 

Given that this situation is an 
accident of history, we should be 
prepared to consider some alterna¬ 
tives. The purpose of this article is 
to propose Modula-2 as one such al¬ 
ternative. 

Modula-2 is a general-purpose 
programming language designed by 
Nicklaus Wirth, the father of Pascal. 
During the last 20 years Wirth has 
defined several structured pro¬ 
gramming languages. Modula-2, the 
latest of Wirth’s linguistic devel¬ 
opments, benefits from its roots in 


Pascal, Modula, and Mesa, a lan¬ 
guage developed at the Xerox Palo 
Alto Research Center (PARC). 
Modula-2 incorporates the positive 
features of its ancestors as well as 
remedies for their difficulties. 

Wirth believes that in the field 
of software design “nothing can re¬ 
place a creative person’s way of 
thinking, ” and after developing 
Pascal he began directing his own 
creativity toward multiprogramming. 
In his experimentation with building 
a language that reaches beyond the 
limitations of Pascal, Wirth defined a 
language, which he dubbed Modula , 
that was strongly oriented toward 
concurrent processing. 

Filled with ideas sparked by his 
experimentation with Modula, Wirth 
left for a year’s sabbatical at Xerox 
PARC. There, he worked with the ar¬ 
chitects of Xerox’s Alto computer, 
the prototype for its Star 8010 Pro¬ 
fessional Workstation, and studied 
the Mesa language. 

When Wirth returned to the 
Swiss Institute of Technology, he 
drew upon his experiences with 
Pascal, Modula, and Mesa to pro¬ 


duce Modula-2. He then designed 
the Lilith machine, a customized, 
micro-coded computer with a high- 
resolution bit-mapped display similar 
to that of the Xerox Alto work¬ 
station. The entire software envi¬ 
ronment of the Lilith was imple¬ 
mented in Modula-2. 


DIFFERENCES FROM 
ITS FOREFATHER 

Although similar to Pascal, Modula-2 
differs from its forefather, both syn¬ 
tactically and conceptually, in four 
distinguishing features. First, the 
basis for program development and 
separate compilation is the module. 
Second, the language supports con¬ 
current processing using co¬ 
routines. Third, the syntax of 
Modula-2 is more systematic. And 
fourth, Modula-2 maintains the 
structure of a high-level language 
while providing for low-level pro¬ 
gramming and machine-level access. 

The most important feature 
that distinguishes Modula-2 from 
other languages is its use of mod- 
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ules, which allow you to extend 
Modula-2 for special-purpose appli¬ 
cations. You can divide large pro¬ 
grams into collections of separately 
compiled modules, and you can then 
place them in a library that different 
programs can use. For example, 
Modula-2, like C, relegates input/ 
output (I/O) functions, system pa¬ 
rameters, and commonly used rou¬ 
tines to modules that are included in 
a standard module library. 

Another important attribute of 
the language’s modules is that you 
can compile them separately, but not 
independently. When you compile a 
program that refers to (imports 
from) a library module, the compiler 
performs complete type checking to 
verify the data compatibility of the 
interface between modules. A cor¬ 
rect implementation of the language 
provides as much checking between 
two separately compiled modules as 
within one module. 

However, the module concept 
goes beyond simple program par¬ 
titioning. Each module itself is com¬ 
posed of a definition section 
(definition module) and an imple¬ 
mentation section (implementation 
module). This sectioning separates 
the interface aspects of a module 
from the implementation details so 
that revisions of the implementation 
module do not affect the interfaces. 

Modula-2’s co-routines allow 
programmers to write powerful in¬ 
terrupt drivers, process schedulers, 
and quasi-concurrent operations 
easily. Co-routines execute indepen¬ 
dently but not simultaneously. 

Modula-2 also has a systematic 
syntax (which provides a better 
bracketing of control and data struc¬ 
tures), an improved case statement, 
and several other less significant im¬ 
provements that make it easy to 
learn and use. 

JULY 1985 


SOFTWARE 

DEVELOPMENT 

Although Modula-2 is a high-level 
language, it was designed for all 
types of software development, in¬ 
cluding the lowest levels of I/O 
drivers, operating systems, and 
read-only memory (ROM) code. It 
provides low-level facilities for ma¬ 
nipulating machine-level data, deter¬ 
mining the memory address of vari¬ 
ables, and accessing peripheral 
device registers residing at fixed 
memory locations. Modula-2 also re¬ 
tains the high-level features of its 

Modula-2 is inherently 
portable; system- 
dependent facilities may 
be easily restricted to 
specific modules. 


predecessor, Pascal, including com¬ 
pulsory declaration of variables, 
clear description of data structures 
and algorithms, and type checking 
of data. 

Because of its special features 
—in particular, its modular struc¬ 
ture—Modula-2 has the potential to 
become a leading programming lan¬ 
guage by the end of this decade. 

The trend of software develop¬ 
ment, for both in-house and market 
distribution, lies with large programs 
designed by teams of programmers. 
Modules are an essential feature of 
this type of large development proj¬ 
ect because they allow for clear and 
explicit division of the program into 
modular parts. The library, to which 
you relegate modules and system 
parameters, facilitates interface be¬ 
tween programmers. 


ate 
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separ; 
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free, 
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build 
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ently 
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Modu 


Consistent with the philosophy 
ijuctured programming, the 
compilation capacity of 
2 helps you to produce bug- 
reliable, and maintainable corn- 
programs because you can 
arge programs from collec- 
of distinct, smaller ones, 
rmore, Modula-2 is inher- 
portable because system- 
ent facilities may be easily re¬ 
stricted to specific modules. 


MPARISON 


a-2 and C have many simi¬ 


larities. Both provide facilities for re¬ 
laxed type checking and direct ac¬ 
cess to memory words and 
addresses. Both also provide prim¬ 
itive o perations close to the level of 
the machine. 

However, the two languages 
also have significant differences. In 
C, memory words and addresses 
are freely accessible, whereas in 
Modu a-2 this access is tied to 
specific language constructs. Fur¬ 
thermore, unlike C, Modula-2 can 
enforce type checking of parameters 
to libi ary routines. Also, Modula-2 
has more extensive low-level capa¬ 
bilities (specifically, support of 
co-routines), and it is a strongly 
typed language. 

la Modula-2, you can override 
type checking systematically, and 
the text of the program indicates ex¬ 
actly what you have overridden. 
This feature is important when 
several programmers are involved in 
the development and maintenance of 
software and when new pro¬ 
grammers will inherit code. 

The concept of modules is the 
strongest attribute of Modula-2. C 
uses independently compiled “com¬ 
pilation units”—source files into 
which you can break a program 
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down—which are similar to the 
modules in Modula-2. C’s “external” 
variables correspond to Mo<dula-2’s 
“imported” objects, or externally 
declared objects that are visible 
within a module. 

The root of the differences be¬ 
tween the compilers, though, lies in 
what a C compiler knows about an 
external object and what a Modula-2 
compiler knows about an imported 
object. A Modula-2 compiler knows 
everything, but a C compiler knows 
little or nothing. 

A Modula-2 compiler performs 
data type checking across compila¬ 


tion units—it performs separate 
compilation. A C compiler does not 
check data types across compilation 
units—it performs independent 
compilation. Separate but not inde¬ 
pendent compilation is another valu¬ 
able feature when more than one 
programmer will be working on a 
program. 

The advantages of more strin¬ 
gent type checking and control over 
module interfaces do not prevent the 
production of efficient code. A re¬ 
cent Modula-2 implementation (by 
Mike Powell, then with the DEC 
Western Research Center in Santa 


Clara and now at uc Berkeley) dem¬ 
onstrated that Modula-2 code can be 
as efficient as C code. 

Modula-2's relevance to the 
Unix system becomes clear when 
you consider the future of comput¬ 
ers. Because of the Unix system’s 
extensive capabilities and progres¬ 
sive adaptation during the past 10 
years, many people predict that it is 
the operating system of the future. 

Modula-2 is a strong candidate 
for the programming language of the 
future primarily because of its modu- 

A Modula-2 

implementation for the 
Unix system would also 
make the development of 
new applications easier, 
safer, and faster. 

lar structure and because of features 
such as its provisions for concur¬ 
rency, portability, and type check¬ 
ing. Because Modula-2 can perform 
type- and consistency checking, its 
libraries offer advantages over avail¬ 
able Unix system C libraries. A 
Modula-2 implementation for the 
Unix system would also make the 
development of new applications 
easier, safer, and faster. In short, 
its modular structure is paving the 
way toward a connection between 
Modula-2 and the Unix system 
world. □ 


Giacomo Marini, a co-founder of Logitech 
Inc., Redwood City, Calif, is vice presi¬ 
dent of that firm’s software division. He is 
responsible for the family of Logitech 
Modula-2 software development tools as 
well as contract software development 
project. Prior to the founding of Logitech, 
he was with IBM and Olivetti. 
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EXPOSING 

the 

PC 

to 

Unix System Connection 

Wait, don’t throw away those dedicated terminals. 

Consider hooking your PC to a Unix system. 


BY ALAN WINSTON 


F ace it. There's a lot to be 
gained by hooking your per¬ 
sonal computer to a Unix 
mmm—m system, ranging from a little 
extra desk space to a powerful new 
multitasking environment for non¬ 
technical users. The range of possi¬ 
ble connections is immense—from 
dumb-terminal connections to full- 
network configurations—and one 
or more of them might be right for 
your application. 

Let’s look a little closer at the 
reasons not to buy a terminal but 
instead to connect the PC you al¬ 
ready have to a Unix system. 

First, buying a terminal costs 
money. The cheapest terminal I’ve 
run across lists at almost $600. 
Terminal-emulator software, which 
will make your PC appear as a familiar 
terminal to the Unix system host, is 
usually much cheaper. 

Second, you have to learn to 
use yet another keyboard. The Mac¬ 
intosh and the IBM PC have idio¬ 
syncratic keyboard layouts that take 
a while to learn. Switching from one 
to another all day can be slow and 
irritating. 

Third, multiplying hardware 
eats up desk space. A few months 


ago I visited the office of a friend 
who was working on some IBM PC 
software. On his desk were a 
special-purpose text-processing ter¬ 
minal connected to the Unix system 
host, a Compaq pc for testing soft¬ 
ware, and a 3270 PC serving as a 
terminal to an IBM system. Although 
all this created a high-tech-looking 
environment, it didn’t leave any 
desktop space for such important 
programming aids as a cup of coffee 
or a telephone. 

Fourth, if you want anything 
fancy, such as a very large display or 
a Dvorak keyboard layout, it’s fairly 
easy to get it on a PC. Although most 
terminals don’t have any provision 
for alternate video output or key¬ 
board reconfiguration, most PCs do. 

If you already have a pc on your 
desk and want to use it as a terminal, 
you have several choices. 

TTY EMULATION 

To start at the least sophisticated 
end of the spectrum, you can easily 
use almost any microcomputer that 
has an rs-232 port as a dumb termi¬ 
nal in tty emulation mode—a mode 
in which the micro acts like a tele¬ 


typewriter terminal. The host sys¬ 
tem communicates line by line, with 
new messages appearing on the bot¬ 
tom line of the screen and old mes¬ 
sages scrolling off the top. This is 
the kind of terminal most on-line 
databases expect, and it is as ge¬ 
neric a communications protocol as 
you can find. 

tty emulation is easy to code 
on the micro. All the PC has to do is 
read one character at a time from the 
communications port, echo it to the 
screen, read the keyboard, and echo 
that key press to the host. This soft¬ 
ware doesn’t take many lines of 
basic or even a great deal of tech¬ 
nical knowledge to produce. More¬ 
over, you don’t even have to code it 
yourself for most micros; vendors 
such as IBM, Kaypro, Apple, and 
many modem manufacturers offer 
tty emulation packages fairly 
cheaply. Such software is often avail¬ 
able free in the public domain, too. 

Running your PC as a tty termi¬ 
nal has its disadvantages, though. 
Any application that requires cursor 
addressability (the capacity to put a 
character anywhere you want on the 
screen) won’t run. This means that 
full-screen editors, word-processing 
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packages, spreadsheets, and so on 
won’t work, vi is a lost cause, al¬ 
though you can still use ed. 

SMART-TERMINAL 

EMULATION 

If you want to run your pc as a smart 
terminal, with cursor addressability 
and page-mode transfer (the ability 
to read everything on the screen at 
once, which is very helpful if you 
want to use the local editing capabil¬ 
ity of your terminal or micro), you 
have two choices. 

Berkeley Unix’s termcap 
offers a means of 
describing new terminals 
to the system so that 
editors such as vi can 
use them without being 
laboriously changed. 

One way is to teach your pc 
to talk to the Unix system in the 
same manner that it talks to a termi¬ 
nal it already knows. Apple sells 
MacTerminal and LisaTerminal, 
which emulate DEC vt-100 terminals 
(among others), for the Macintosh 
and Lisa, respectively. 

More terminal emulators are 
available for the IBM PC than I can 
count, and they are also available for 
various CP/M systems. (The Kaypro 
uses the same control sequences as 
the adm-3a terminal, which makes 
that emulation a breeze.) Emulators 
are available for many popular termi¬ 
nals on many popular micros, and if 
the particular terminal you want isn’t 
supported on the particular PC you 
have, it’s reasonably straightforward 
for a programmer to write one. 


FIGURE 1: T E R MIN A L 
CHARACTERISTICS 


Terminal 

Characteristics 

co —number of columns 
(numeric) 

1 i — number of lines 
pt — physical tabs (Boolean) 
os —overstrike capability 
(Boolean) 

he —hardcopy terminal 
(Boolean) 

Screen Movement 

bs —backspace capability 
(Boolean) 

am — automargins (Boolean) 

up — cursor up 

nd — nondestructive forward 

cm — cursor motion 

ho — home 

sr — scroll reverse 

do — down 

bt — back tab 

hd — halfiine down 

hu — halfline up 

Screen Updating 

cl — clear entire screen 
ce — clear to end of line 
cd — clear to end of display 
dl — delete line 
al — add line 
dc — delete character 
im —insert mode 
e i — end insert mode 
i c — insert character 

Arrow and Function 
Keys 

ku — keyboard up 
kd — keyboard down 
kl — keyboard left 
kr — keyboard right 
kb — keyboard backspace 
kh — keyboard home 
ks — keyboard start (for special 
keypad work) 

ke — keyboard end (for special 
keypad work) 

kn — number of function keys 
(numeric) 


kN — function keys (N equals 1 
through 10) 

Highlighting 

so — standout 
se — standout end 
ue — underscore end 
us — underscore start 
vb — visual bells 
sg — standout glitch 
ug — underline glitch 


Software Control 

tc —use another termcap 
definition 

is — initialization string (for set¬ 
ting options) 

if — initialization file (for setting 
tabs, etc.) 

ma — map (for old versions of 
vi) 

te —terminal end (for cursor 
motion) 

t i — terminal initialize (for cur¬ 
sor motion) 

ve — visual end (for vi) 

vs — visual start (for vi) 

ae — alternate character set end 

as —alternate character set 
start 


Special Characteristics 

ip — insert pad after each char¬ 
acter inserted 

mi — safe to move in insert mode 
xn — newline glitch 
11 — last line, first column 
nl — newline character if not A J 
ta — tab character if not A I 
be — backspace character if not 
A H 

pc — pad character if not NULL 
cr — carriage return if not A M 
ms — safe to move in standout 
cs —change scrolling region 
(vtlOO) 

bw — backspace wraps from col¬ 
umn 0 to last column 


Continued on pa^e 63 
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EMERALD ONE 


J 


TM 



SOFTWARE WITH 
COURAGE, 

BRAINS AND HEART 


WHAT IS EMERALD iONE? ! 

The most complete integrated office system available 
today, EMERALD ONE combines the most essential 
office tasks through six fully compatible and seamless sets 
of tools. EMERALD ONE runs on a broad range of 
mainframe, mini, super-micro and personal computers 
which use the UNIX™ operating system-the emerging 
standard for the office. 


EMERALD ONE integrates your office tasks through: 

1. COMMUNICATIONS, including Telephone 
Messaging and Electronic Mail systems, 

2. INFORMATION HANDLING with EMERALD 
ONE’s powerful Relational Database system, 

3. DECISION SUPPORT features such as Business 
Graphics and the Electronic Spreadsheet, 

4. DOCUMENT PREPARATION with Word 
and a Cabinet, Document and File Folder system 

5. TIME MANAGEMENT tools such as the 
Personal Diary system and Meeting 
Scheduler and 

6. SYSTEM ADMINISTRATION functions 
that allow a non-technical user to 
customize EMERALD ONE 
for the individual, work group 
and organization with ease. 


SOFTWARE FORT] 


EMERALD ON 
computer softwan 
groups. With E1V 
nicating group, n< 
a document, spn 
thing created with 
easily between i 


goed far beyond stand-alone personal 
e by linking individuals and their work 
ERA X) ONE, users work as a commu- 
ot as isolated individuals. Whether it be 
•^adsheet or personal diary entry, every- 
EM 2RALD ONE can be exchanged 
ividuals, work groups and beyond. 


irid 


EMERALD CI T 
EMERALD OIS 


Y, TpE PEOPLE BEHIND 
E 


in 


EMERALD ONE is th|e 
research commitment 
pany Trigon Systems 
consulting companies 
Attractively priced for di 
facturers, system integral 
ONE is fully supportec ‘ 
gram designed to assist 
integrated office market, 
a complete busir ess so 


Emerald City, the 


iE WORK GROUP 


result of an intensive, multi-year 
3y Emerald City and its sister com- 
Group, one of the most respected 
office integration, 
listribution by hardware manu- 
tors and OEM’s, EMERALD 
by an extensive marketing pro¬ 
distributors in penetrating the 
. Emerald City offers the reality of 
ution, not just technology. 


company with courage, brains and heart. 


ES1ERALD 

CITY 


20 Richi 
Tordni 


emerald City Inc. 

Street East, Suite 700 
to, Canada M5C2R9 
863-9923 


imond i 


UNIX is a trademark of Bell Labs 
EMERALD ONE Is a trademark of 
Emerald City 




















We’re Expanding 
Our Line With AT&T 


/ t gives us great pleasure to 
announce ABS has become 
a value added reseller for 
AT&T! 


Naturally we’re proud. And very excited. Not only 
about the products. But also because we can serve 
you better. With just the right systems. Software 
that works. And all the support you’ll need. 

As for the 3B line of computers. These great per¬ 
formers are rugged, reliable tools that come 
equipped with UNIX* System V, the multi-user, 
multi-tasking operating system, that is the indus¬ 
try standard. 

At ABS, we wanted to offer you the best 
UNIX system on the market. So we went 
with the leader, AT&T. After all, we’ve 
built our reputation on personal service, 
prompt deliveries, and products that 
are the top of the line. 

AT&T 

Personal Computer 6300 
3B2/300 Multi-User Desk Top Computers 
3B5 100/200 

3BNET Local Area Network Interface 

UNIX SYSTEM V& Utilities 

“C” Language Basic 

Fortran 77 Pascal 

Cobol 


SOFTWARE 

Data Base Packages 
Word Processing 
Spread Sheets 
S Software 
Graphics 


Business 

Office Automation 
Material Handling 
Engineering & Scientific 
Data Communications 


AND MORE ... From ABS. 

Digital equipment and DEC* compatible 
products are readily available from ABS, along 
with a variety of software packages. 




Give us a call today and line up with leaders. 
You'll be glad you did. 




ABS ASSOCIATES, INC. 


3550 Salt Creek Lane 
Arlington Heights , IL 60005 
(312) 577-7752 


UNIX is a trademark of AT&T Bell Laboratories. DEC is a trademark of Digital Equipment Corporation. 
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REVIEW 


Mt|trs80|trs-80|radio shack trs-80 model I:\ 


:am:bs:c 

;o#64:1i#16: 


Ma|apple2|apple I! 

I (unextended) : \ 


:am:bs:< 

>s:co#69:li#24:cl A L: 



FIGURE 2: TERMCAP ENTRY FOR TRS-80 AND APPLE II 


kb|hl9|heath|hl9b|heathkit|heath-19|zl9| zenith|heathkit hl9: \ 


:am:bs:mi:ms:pt 

: co#80 : li#24: cl =\EE: cd=\EJ : ce-\EK : cm=\EY% + 


%+ \ 



: al = l*\EL.: dl =! 

L*\EM : ei = \E0 : im = \Ef« :dc = \EN:up=\EA:do=\EB: nd = \E< 

3 \ 

:ho = \EH:as=\EI 

F*: ae = \EG : sr = \EI: so = \Ep: se = \Eq : vs = \Ex4 : ve~\Ey4 : \ 


:kb= A H:ku = \EA: 

kd~-\EB : kl = \ED: kr = \EC: kh = \EH : kn#8: \ 


: kl = \ES: k2 = \E' 

r:k3 = \EU: k4 = \EV:k5 


= \EW: k6 = \EP: k7=\EQ: kJ 

3 = \ER: 



FIGURE 3: TERMCAP ENTRY FOR H89 AND Z89 


z8|trs80i i|trs-80 
:am:bs:p 

%+ :\ 

-II|radio shack trs-80 model II (P&T CP/M) :\ 

>t: ms: co#80 : li#24 : cl = A L: ce = A A cd - A B : cm- \EY%+ 


al = A D:dl = A K:h<i= A F: up 
:kb A H kd A -:k 
z2|apple2e|applell|apple I 

A A do= A --: nl = A - : nd - A |: se- A 0: so- A N: \ 

1 A \: kr- A ]:ku AA 
:i plus: \ 


:am:bs:pt. :co#80: 
%+ : \ 

:1i#24:c 

1 A l 

L:ce- A J: cd = A K : cm- A A %r% + 


: is = \024Tl\016 : so = A 0 : se ~ ^ 
:vs = \024\103\066: 
zi|apple-80|apple II with smar 

‘N: ho-\E A Y: nd- A \:up- A -:do- A J : ma = A ul:\ 
ve = \ 024\103\062 : vb=\024Gl\024Tl: 
term 80 col: \ 


:am:bs:co#80:lif 
%+ '■ N 

*24:cl=J 

?0 A L 

: cd = 50 A K : ce = 3 A ]: cm-5 AA %%+ 


nd=2 A \:up = 2 A 

do - A J b 

t = 2 A 

l R: is-TR A V A A 



FIGURE 4: TERMCAP ENTRY FOR TRS-80 II AND APPLE HE 


A colleague of mine just spent 
three weeks writing a program to 
emulate a Televideo 950 on an IBM 
PC. (It took him that long only be¬ 
cause he was at first unfamiliar with 
the Intel 8086 assembler and had to 
learn it to write the code.) 

The second choice is to teach 
your Unix system to talk to your pc. 
The Berkeley Unix system offers a 
means of describing new terminals 
to the system so that editors such as 
v i can use them without being labo¬ 
riously changed. Called termcap, 
this text file is a database of terminal 
descriptions, each one containing 
appropriate information—such as 
cursor-positioning sequences, back- 
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face, 
a vt- 
do. 
ation 


or 

100 


An 


do anything at all for you that 
or a TeleVideo 950 won’t 
id for many novices, this situ- 
bresents a problem. 


BRIE GING THE GAP 


Several 
reaches 
gap be 
popuk r 
running 
annout 
site 
PC 


: tes 
and 


space characters, number of lines on 
the screen, how to highlight parts of 
the screen, what values the function 
keys return, and other vital infor¬ 
mation—for each major terminal and 
many popular pcs. 

A new entry in the termcap 
file may suffice to enable you to use 
your pc as a smart terminal. Re¬ 
printed in Figures 1 through 6 are 
some sample personal computer 
termcap definition files from Bill 
Tuthills termcap tutorial articles 
in Unix/World, Vol. 1, Nos. 1 
through 3. 

However, nothing I’ve de¬ 
scribed so far will handle file trans¬ 
fers, present a “user friendly” inter¬ 


products have recently 
d the market that bridge the 
tween the Unix system and 
pcs (mostly IBM and those 
ms-dos). Others have been 
iced and are currently in beta- 
ting. These products use the 
the host to better advan- 


Several products have 
reached the market that 
br dge the gap between 
the Unix system and 
popular PCs. 
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some of them may even 
it worth buying a PC and get- 
of the terminal. 

One “bridge” product con- 
g MS-DOS and Unix systems is 
L|ocus PC Bridge, from Locus 
ting Corp. (Santa Monica, 
This product, which was re- 
fully in Vol. 1, No. 6 of 
vjWoRLD, makes the Unix sys- 
ftle server for the PC, which is 
the simple impression that it 
very big disk drive. 

PC applications run locally 
n take data from the Unix sys- 
across a local-area network 
link, such as Ethernet or 
is Net. This lets the execu- 
wants to run Ashton-Tate’s 
III against massive files on 
(lost do it without worrying 
where the data live and what 
ly qualified name of the file is. 
never have to know that the 


cai 


host; 


who 


full 
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REVIEW 


Mo|osb|osbornel;osborne 1:\ 

: bs : ms : xt: co#80 :li#24:cl~ A Z. ce = \ET: cm = \E=%+%+ :\ 

: up- A K:do- A J : nd A L: ic = \EQ:dc- \EW:al = \EE. dl= \ER: im= : ei = : \ 
:ku = A K:kd- A J : kl A H: kr = A L : so = \E) : se-\E( : ul: us -\E1: ue \.Em: 


FIGURE 5: TERMCAP FOR OSBORNE I 


Mf|f 100|freedomlOO!freedom|freedom 100 by Liberty :\ 

: am: bs : bw: mi : ms: pt: co#80 : li#24 : kn#20 : ct = \E3 : st = \El: is = \Eg\Ef: \ 

:kr~ A L:cl~ A Z:up= A K:do- A J: ho = AA :kb- A H:kl - A H: \ : kd~ A V:ku- A 
K: nd = A L: \ 

: ko=dc . al. dl. cl. bt. ce. cd: ma - A Hh A Vj A Kk A Ll A A H A Z A L: \ 

: ch- \E]% + : cm- \E~ %> + %■* : cv = \E[%+ : sr = \EJ : bt = \EI: \ 
:al-6.5*\EE:cd = \EY: ce = \ET:dc = \EW:dl = 11.5*\ER: ei \Er : lm \Eq:\ 
: se = \EG0 : so = \EG4 : ue- \EG0 : us = \EG8: as=\ES: ae = \E$ : \ 

: kl = A A('« \r: k2 = A AA\r: k3 - A AB\r:k4 A AC\r : k5 = A AD\r : \ 

: k6= A AE\r : k7= A AF\r : k8= A AG\r : k9~ A AH\r: kO = A AI \r : \ 

: hs : ts-\Eg\Ef: fs = \r : ds = \Eg\Ef\r 


FIGURE 6: TERMCAP FOR FREEDOM AND MICRO DECISION I 


Unix system is on the other end of 
the wire. 

Another part of the product is a 
terminal emulator, which does 
input/output (I/O) to the host in 
screen-size blocks, requiring only 
one interrupt for the entire transfer. 
This considerably reduces the load 
on the host compared to one inter¬ 
rupt per character, and makes a 
substantial difference when several 
users are running vi, for example. 

Locus’ strategy is to sell only to 
original equipment manufacturers 
(OEMs), so the price is dependent on 
where you buy it. As far as I know, 
AT&T is still the only OEM of this 
product, which means that the only 
hosts you can buy it for are the 3B 
series computers. 

Another software product that 
distributes the load of editing and 
text production away from the Unix 
system host and down to a PC 
—in this case, even an IBM PCjr— 
is Sprouts, a family of software 
products from Slater Towar (Estes 
Park, Colo.). 

The first of these products, the 
Writer, is in beta test as I write and 
was due for release by February. In 
essence, it is a “what you see is 
what you get” text and graphics edit¬ 
ing system that displays user- 
definable characters—including 
graphics characters and charts— 
formatted exactly as they will be 
printed, even down as far as propor¬ 
tional spacing. This could be a great 
aid if you want to produce publica¬ 
tions that integrate text and graphics 
in a single document, and it costs 
substantially less than, say, a Xerox 
publication system. 

According to the company, the 
Sprouts family will be able to use 
data from another machine so that 
the editing terminal—which re¬ 
quires only 128K bytes and a graph¬ 
ics card—can edit files much too big 


for any of its local storage. Slater 
Towar will be offering a cartridge 
version for the PCjr so that it can run 
as a diskless workstation and edit 
large files on a Unix system host. 

The Sprouts package also al¬ 
lows the PCjr to run as a standard 
terminal. The only difference is that 
text sent to the screen is formatted 
as it comes in, and you can then cap¬ 
ture and manipulate it as desired. 
File-server software is required on 
the host and is included free with the 
purchase if that host machine is 
already supported. If it isn’t, Slater 
Towar requires a minimum order 
of 400 copies (at $50 each) to make 
the port. 

DOING THE TANGO HELPS 

Commercial Office Systems Inc. 
(COSI) of Ann Arbor, Mich., offers a 
product now called Tango but origi¬ 
nally known as Communique. Tango, 
I suppose, is easier to pronounce. 

To a Unix system host, Tango 
emulates a vt-52, vt-100, ibm 3101, 


or Tektronix 4010 graphics terminal, 
either through a modem or directly. 
Even when logged on to the Unix 
system, users can direct the PC to 
execute an ms-dos program using 
the pc exec command. File transfer 
is supported with handshaking to en¬ 
sure data integrity, using commands 
such as p u c p to copy from the PC to 
the Unix system and upcp to copy 
from host to pc. Users can direct 
program output from host to PC or PC 
to host. Furthermore, they can di¬ 
rect the host to run a program on a 
PC other than the one from which the 
command originated. 

On the PC side, Tango has capa¬ 
bilities such as automatic log-in, 
auto-dial of numbers, and execution 
from a “script” stored in an ms-dos 
file. Tango runs on IBM pcs and com¬ 
patibles that have 128K bytes of ram 
and MS-DOS Version 2.0 or higher. It 
runs in conjunction with any host 
operating system that supports ascii 
file transfer, but the company claims 
it does significantly more on a Unix 
system, at&t will market it for the 
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REVIEW 


3B series and at&t 6300 pcs, and 
cosi itself sells Tango for many differ¬ 
ent Unix system machines and PCs. 

The Connectables series from 
Touchstone Software (Seal Beach, 
Calif.) networks IBM PC-compatibles 
and Macintoshes as workstations 
with a Unix system host. The Con¬ 
nectables family currently includes 
pcworks for ms-dos machines, Mac- 
Line for the Macintosh, and UniHost 
for one of the more than 50 host 
machines that Touchstone supports. 
Each package provides file and docu¬ 
ment transfer from all workstations 
to the host or to each other, elec¬ 
tronic mail, and terminal emulation 
(of vx-52 and vt- 100 terminals). 

The Unix system can either be 
used as a “command server,” per¬ 
forming i/o for the PC user with¬ 
out requiring special knowledge of 


Unix, or it can be logged in to di¬ 
rectly or through a menu. Various 
levels of technical knowledge are 
supported, making this system ap¬ 
propriate for everyone from a secre¬ 
tary to a programmer. 


Don’t throw away your 
dedicated terminals; 

I hear they make great 
paperweights. 


In sharp contrast to this ap¬ 
proach is Ultra-Mac, from Lutzky- 
Baird Associates of Culver City, 
Calif. This Macintosh software, now 
in beta test, will not provide terminal 
emulation capability at all. In fact, 
the Unix system interface is off- 
limits to the Ultra-Mac user, who is 


expected to be a nontechnical 
type—such as an advertising 
copywriter—working with others 
on a team project. 

Ultra-Mac displays a hierarchy 
chart, something roughly akin to a 
genealogical chart on the Macintosh, 
and this chart contains only the por¬ 
tion of the Unix file system that a 
given user is allowed to access. By 
using the mouse, the user selects a 
file to check out—to copy to his or 
her local diskette. The user can then 
edit the file with MacWrite or Micro¬ 
soft Word and check it back in—all 
without ever knowing the Unix sys¬ 
tem is on the other end. Also part of 
the product is a Unix system-com¬ 
patible electronic-mail system that 
facilitates communication between 
people working on related projects. 

Subsequent releases will in- 


SAMPLING OF PC/UNIX SYSTEM LINKS 



Tango 

COSI (Ann Arbor, Mich.) 
(Soon to be available 
through AT&T) 

Locus PC Bridge 
Locus Computing Corp. 
(Santa Monica, Calif.) 

Ultra-Mac 

Lutzky-Baird Assoc. 
(Culver City, Calif.) 

Sprouts 
Slater Towar 
(Estes Park, Colo.) 

PCWorks 

Touchstone Software 
(Seal Beach, Calif.) 

MacLine 

Touchstone Software 
UniHost 

Touchstone Software 


REQUIREMENTS 

IBM PCs and compatibles 
with 128K-byte RAM and one 
disk drive; supports “a variety” 
of Unix system hosts. 

IBM PCs and compatibles with 
64K-byte RAM, one disk drive, 
and LAN connection. 

Apple Macintosh with 128K- 
byte RAM and Zilog or Charles 
River host LAN—Applebus or othjer. 

Any model of IBM PC with 
128K-byte RAM and a graphics 
monitor; various host 
systems. 

IBM PC or compatible with 
I28K-byte RAM, 280K-byte disk 
storage, MS-DOS 2.0 or 
later, and RS-232 port and cable. 

Apple Macintosh with 128K-byte 
RAM, and RS-232C port and cablje 

More than 50 different Unix 
systems with 30-60K-byte disks 
and serial log-in ports. 


PRICE HOST/PC 
$295/$195 

OEM only 

$1595/$200 

free/varying 
from 1 @ $80 
to 500,000 @ $10 

$195 

$145 

$295 
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REVIEW 


PREVIEW: MULTIPLEX AND RTFs INGRES PC LINK 


Interest in PC-to-Unix system 
gateway products is rising, and 
products that address this need 
are among today’s hottest sell¬ 
ers. But anxious users may 
quickly find that many of these 
gateways don’t go far enough. 

And that’s where Network 
Innovations’ new Multiplex 
PC-to-Unix-system connection 
software comes in. It goes one 
(and maybe two) steps further 
than many competitive prod¬ 
ucts, providing not only for file 
storage and resource sharing, 
but also for data interchange 
between the most popular PC 
applications programs—Lotus 
1-2-3, dBase II, WordStar, Mul- 
tiMate, Multiplan sylk, and 
VisiCalc DIF files—and Unix 
system-based relational DBMSs. 

Typically, most PC-to-Unix- 
system gateway products al¬ 
low the PC to run off-line as an 
MS-DOS engine and on-line as a 
standard Unix system termi¬ 
nal, and to share the Unix sys¬ 
tem’s typically larger, more 
powerful, and usually more ex¬ 
pensive peripherals. 

However, that’s as far as 
most of those products go. 

Multiplex allows an end- 
user to take a Multiplan file 
using Microsoft’s sylk data for¬ 
mat, for example, to store a 
spreadsheet in a Unix system- 
based relational DBMS and to 
later call it up from an ASCII ter¬ 
minal as a standard Unix sys¬ 
tem file. Multiplex converts 
Unix system files to PC files for 
Lotus, Multiplan, MultiMate, 
VisiCalc, dBase II, and Word¬ 
Star, as well as for any other PC 
applications software that sup¬ 


ports those packages’ file for¬ 
mats. And vice versa. 

Introduced rather quietly 
at this year’s UniForum ’85 
conference in Dallas, Multi¬ 
plex is the first product of 
startup software house Net¬ 
work innovations of San Jose, 
Calif., and is the brainchild of 
co-founders Jim Groff (presi¬ 
dent) and Paul Weinberg (vice 
president), both of whom are 
former Plexus staffers. 

Multiplex’s capabilities are 
all housed behind a Lotus-like 
front-end to boot, so the 
800,000 or more Lotus users 
in corporate America won’t 
have to learn a new set of com¬ 
mands. And at the back-end, 
Multiplex supports SQL or SQL- 
like interfaces to the DBMS. 
Currently, it works with Unify, 
Relational Database Systems’ 
Informix, and Relational Tech¬ 
nology Inc.’s Ingres under Sys¬ 
tem III, System V, 4.2BSD, and 
Xenix. 

Multiplex’s license fees 
are quite reasonable, about the 
price of a popular PC software 
package—$595 for a Plexus- 
class Unix system host and 
$125 for each PC. 

The first commercial im¬ 
plementation of Multiplex to 
reach end-users will likely re¬ 
sult from Network Innova¬ 
tions’ recently announced OEM/ 
joint development agreement 
with Relational Technology 
Inc. (RTI) of Alameda, Calif. RTI, 
perhaps best known as the pur¬ 
veyors of commercial Ingres, 
will market the product as 
Ingres PC Link. 

—Philip. J. Gill 


elude print spooling, Unix system 
terminal capability, and use of the 
Unix system as a “disk” for the Mac¬ 
intosh. This last capability will elimi¬ 
nate the need for documents to be 
downloaded to a local floppy. Later, 


similar capabilities will be imple¬ 
mented for the IBM PC, according to 
Lutzky-Baird representatives. 

Lutzky-Baird said that the non¬ 
technical users in the firm’s beta-test 
site love the product and don’t 


want to give it up when the testing 
is over. As unusual as that might 
sound, that’s how you might feel 
about any one of these products or 
any one of the other PC-Unix system 
connection products on the horizon. 
Don't throw your dedicated ter¬ 
minals away, though. If noth¬ 
ing else, I hear they make great 
paperweights. □ 


Alan Winston is a freelance writer and 
full-time programmer I analyst who has 
been interested in the Unix system for 
several years . His last work for 
Unix /World Magazine appeared in the 
June 1985 issue. 

/ ” \ 


FRANZ 

THE FIRST 
NAME IN 

LISP 

Franz Lisp from Franz Inc. 
is currently available on a 
wide range of machines 
under UNIX and VMS. 
Franz sets the standard for 
Lisp. Call or write for 
more information. 

FRANZ INC. 

2920 Domingo Ave. Suite 203 
Berkeley, California 94705 
(415) 540-1224 

UNIX is a trademark of Bell Labs. VMS is a 
trademark of Digital Equipment Corporation. 


_____ 
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IN SEARCH OF SOFTWARE EXCELLENCE 

AT&T LEADS THE WAY 


AT&T COMPUTER 
SOFTWARE GUIDE 

AT&T Information Systems, Inc. 

Announcing Certified and 
Reviewed software for your 
AT&T computer 

Here is the authorized reference 
of software products for the 
AT&T 3B2,3B5 and 3B20 
computers utilizing UNIX™ Sys¬ 
tem V and the AT&T PC 6300 
running MS™-DOS. This guide 
is the source when making intel¬ 
ligent decisions regarding your 
purchase of hardware and soft¬ 
ware. The AT&T COMPUTER 
SOFTWARE GUIDE contains 
over 500 pages of definitive 
listings including: 

• Company and Product Name 

• Application Category 

• Product Description 

• Programming Language 

• Hardware and Software 
Requirements 

• Support 

• Computer 

• UNIX™ System V Release No. 

• Availability/Retail Price 
Distributor 

This striking guide includes a 
full color advertising section and 
multiple indexes. 



AT&T 

COMPUTER SOFTWARE GUIDE 



Please Rush 

_copies of The UNIX™ System V Software 

Catalog R8068-0 ($19.95) each. 

_copies of the AT&T Computer Software 

Catalog R9276-8 ($19.95) each. 
□ Bill me □ Check Enclosed 

Name_ 


Company 
Address _ 


City/State/Zip _ 

Phone Number _ 

Please include your state's sales tax. 

Enclose payment with your order and publisher 
pays shipping, up to 6 books. 



R 


Reston Publishing Company, Inc. 

11480 Sunset Hills Road 
Reston, Virginia 22090 
(703) 437-8900 within Virginia 
1-800-336-0338 outside Virgin^ 
Hours are 9 am to 5 pm EST. 

V-0955-8|H(9) 


THE UNIX™ SYSTEM V 
SOFTWARE CATALOG 

AT&T Technologies, Inc. 

UNIX™ System V sets the stan¬ 
dard—here is your authorized 
reference manual. 

This is the new AT&T catalog 
of software products designed 
to run under the popular UNIX™ 
System V. THE UNIX™ SYS¬ 
TEM V SOFTWARE CATALOG 
demonstrates how the UNIX™ 
operating system works as a 
common denominator for dif¬ 
ferent computer hardware and 
software. This comprehensive 
manual provides over 200 objec¬ 
tive, non-evaluative listings of 
software products including the 
following information: 

• Company Name 

• Product Name 

• Application Category 

• Product Description 

• Programming Language 

• Code Format 

• Hardware and Software 
Requirements 

• Computer Systems Support¬ 
ing the Product 

The attractive UNIX™ SYSTEM 
V SOFTWARE CATALOG con¬ 
tains multiple indexes by 
Company, Product and Category 
for easy reference. 
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MCBA 

introduces 

shrink-to-fit 



With nine years in 
minicomputer software, 

15,000 installations worldwide 
and an established reputation in 
the mini world, MCBA is proudly 
shrinking its software line. 

Down to micro size. 

We’ve taken the impressive power 
of minicomputer software and made it 
available for micros. Right now. 

Alter the fit? Absolutely. 

Alter the functionality, modularity 
and capability? Not one bit... so to speak. 

This new line of serious micro¬ 
computer software is by far the most com¬ 
prehensive, well-tested and sophisticated 
in the industry today. By whose standards? 
Thousands of MCBA users who rank it the best 
in the business. 

MCBA’s library of 16 inte¬ 
grated manufacturing, distribution 
and accounting packages can be 
installed in whatever combination 


mm 
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sequence a user 
for his or her 
business. 

It grows with 
businesses. No matter 
what size they are now. 
Or want to be later. 

And MCBA software 
now runs in RM/COSf 
PC-DOS, UNIX™ 
and UNIX look-alike 
environments. 

In other words, 
we’ve tailor-made our 
newest software to fit 
micros—as comfortably 
as it fits user needs. 

So whether you’re a 
dealer or a user, find out 
about it. Call us now at 
(818) 957-2900. 

Shrink-to-fit software. 

For growing businesses. 


Minicomputer Software for Micros 

2441 Honolulu Avenue, Montrose, California 91020 

Also for DEC, Wang, HP, TI, and Perkin-Elmer minis. 


islired trademark ••( MCBA. Inc I *NIX i> a irad.mark ..f AT&T. KM COS i- 


isn-red trademark of Kyan McFarland C«»n*. 
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THE 

5486: 

AN AT’ E 

SUSTER? 


by bruce mackinlay This month ourgonzo reviewer discusses the crazy 

notion of competing directly with IBM. 



“C 


ompete directly with gi¬ 
ant IBM, are you crazy?” 
But that is just what little 
Altos is doing with its 
486, a Xenix-based multiuser super¬ 
micro for small businesses. So the 
question is, how does the Altos 486 
compare to the IBM PC/AT? To find the 
answer to that question, read on. 

The Altos 486 has a number of 
things going for it in its battle against 
the PC/AT. First, it is an Altos, and 
Altos has a good reputation for 
making quality machines. Second, it 
is cheaper than the PC/AT (“at” 
for short). A comparably equipped 
PC/AT costs $7315, while the 486 
costs $6490, excluding title, desti¬ 
nation, and license. Finally, and most 
important of all, the Altos 486 is one 
of a family of machines, from the 186 
to the 986, that are tried-and-true 
small-business machines. So the 
long and short of it is that the Altos 
486 has a lot going for it. (The newly 
introduced 3068, though, is not a 
member of this family.) The real 
question is, will this be enough? 
Many bigger companies with better 
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WE'RE THE EMPLOYEES 
OF FORTUNE SYSTEMS. 

WE 


WE BOUGHT THIS AD 
TO TELL YOU SO. 


Last month the employees of Fortune Systems did something extraordinary. 

They took up a voluntary collection to place this message in UNIX World. 

What motivates employees to spend their hard earned cash to make such a statement? 

It’s simple. They’re very proud of what they do. 

And with reason. It is a damned good computer system. Just ask the people who build it. 
Or ask our thousands of customers. They’ll tell you the same thing. 

The employees of Fortune Systems believe in their product. 

As President of Fortune Systems, I believe in them. 

FORTUNE SYSTEMS 
IS A DAMNED GOOD COMPANY. 
AND I BOUGHT THIS AD 
TO TEIL YOU SO. 
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products have succumbed to IBM's 
iron fist. 

The Altos 486, which fills the 
gap between the 186 and the 586, 
is a one-to-four-user Xenix-based 
business system. All the Altos 
*86 family machines are cross¬ 
compatible, meaning that software 
on one will work on another without 
recompiling; the IBM PC, PCjr, and 
PC/AT, on the other hand, don’t have 
this capability. 

Furthermore, the Altos *86 
machines all support WorkNet, 
Altos' proprietary network. Cur¬ 
rently, IBM does not support any 
form of networking on Xenix. If you 
are running a small business in which 
you need a small time-sharing sys¬ 
tem, then you should consider an 
Altos; if you have an Altos *86 ma¬ 
chine and need four more terminals, 
then you should consider the 486. 


At $6490, the Altos 486 in¬ 
cludes 512K bytes of random-access 
memory (ram), 21 Mbytes (for¬ 
matted) hard disk, five rs-232 ter¬ 
minal/printer ports, one WorkNet 
local-area network (LAN) port, an 
Altos III terminal, and Xenix. One 
thing that sets the 486 apart from 
the PC/AT is that the 486 is a com¬ 
plete working Xenix (I have a habit 
of pronouncing this Unix) computer. 
With the PC/AT, you need to add 
significant hardware and software to 
get a working multiuser system. 
This makes the real (working) price 
of the 486 lower than that of the 
PC/AT. 


HARDWARE 

The most attractive feature of the 
Altos 486 is that it is an all-in-one 


computer system. As noted above, a 
basic 486 Xenix system includes one 
Altos III terminal. Furthermore, as 
you grow to the maximum of four 
users, all you need to add is a termi- 

The Altos 486’s most 
attractive feature is 
that it is an all-in-one 
computer system. 

nal for the second, third, and fourth 
users; no other additional hardware 
is required. Compare this to the IBM 
PC/AT, where you have to be an en¬ 
gineer to put together a Xenix sys¬ 
tem or have to pay top dollar to have 
someone else put it together. If you 
can recall the old Osborne I (it only 
seems long ago), its most attractive 
feature was the fact that it was an 
all-in-one computer, including the 
application software (hint, hint). 

In addition to local-area net¬ 
works, the 486 also supports 3270 
and 3780 bisynchronous. You can do 
this with an IBM PC/AT (PC Path), but 
again you have to purchase extra 
(expensive) hardware. Also, there is 
WorkNet hardware for the IBM PC, 
allowing you to share the Altos 486 
Xenix disk drives between multiple 
IBM PCs. This will allow you to get 
some of the advantages of time¬ 
sharing with your current set of IBM 
PCS. 

I can never resist the tempta¬ 
tion to open the machine and look at 
the hardware. Altos made this sim¬ 
ple by including an overview of the 
hardware (this is standard with the 
machine). The 486 design is very 
clean; it should have a long mean 
time between failures and will be 
easy to fix when it does fail. How¬ 
ever, if you are not an engineer, you 
will have to go to Altos or to an Altos 
dealer for repairs. 


COMPANY OVERVIEW 


Company name 
Public/private 

Stock symbol 
In business since 
Headquarters 

CEO 

VP marketing 
General sales contact 


Net sales 
Net income 
Employees 

% of total expense 
spent on R&D 

Units shipped 
Other major products 

Major funding 


Altos Computer Systems 
Public 

Traded over the counter 

ALTO 

1977 

Altos Computer Systems 
2641 Orchard Parkway 
San Jose, CA 95134 

David Jackson 
Philip White 

Ron Conway, 

Vice President, Sales 

1/2 FY ’85 FY ’84 

$59,991,000 $102,739,000 

$5,489,000 $9,748,000 

600 550 

6 % 6 % 

N/A 30,000 

Altos 186, 586, 986, 986T, 3086, 
and Altos III terminal 

No long-term debt 
No venture capital 
$15 million untapped credit line 
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On the other hand, you should 
be able to get a PC/AT fixed at almost 
any retail computer store. 

While the Altos 486 is the em¬ 
bodiment of completeness, the PC/ 
at is the picture of expandability. 
With the PC/AT you have five slots 
free, whereas the 486 has only one 
slot. Actually, once you add four 
serial ports and networking, you are 
down to three slots. Here’s a sug¬ 
gestion: Don’t buy the IBM serial 
cards, they waste slots. This makes 
the PC/AT much more flexible and 
more expensive. The question is, do 
you need this flexibility. I would, but 
a small business would not. 

Also, you can expand the PC/AT 
to have up to 3 Mbytes of internal 
memory, but the 486 is limited to 1 
Mbyte (expansion from 512K bytes 
was scheduled to become available 
in June). Although this might seem 
like a big difference, it really isn’t. 
Experiments with the PC/AT running 
Xenix show no real improvement in 
speed above 1 Mbyte of memory. 
On a four-user business system, you 
just don’t need more than 1 Mbyte 
(except with large spreadsheets). 
With all this said, I still think the 
PC/AT beats the 486 on expandability 
and flexibility. 

FLOATING POINT 
RESULTS 

Comparing the 486’s floating point 
results to those of the PC/AT is very 
interesting. The PC/AT without float¬ 
ing point hardware is very slow, while 
the 486 is significantly faster. The 
PC/AT is so slow that I strongly sug¬ 
gest that you put an 80287 chip into 
your PC/AT. The 486, on the other 
hand, is fast enough for a business 
system. The only reasonable expla¬ 
nation for this difference is that non¬ 
hardware floating point operations 
on the PC/AT result in substantial 
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ALTOS 486 VS. IBM PC/AT 


Note: The ratios in the following section reflect the number of times 
faster that the IBM PC/AT is over the Altos 486 running Xenix 
3.0. The numbers in parentheses show where the 486 outperforms 
the PC/AT. 

* Numbers not available for IBM PC/AT 

Arithmetic Instruction Times 



short 

long 

float 

double 

+ Add 

1.015 

1.131 (10.062) 

(9.714) 

* Multiply 

1.422 

1.231 

(9.729) 

(7.390) 

/ Divide 

1.501 

1.194 

(8.708) 

(5.707) 

Arithmetic Instruction Times 



(with 80287 floating point chip 

in the IBM PC/AT) 


short 

long 

float 

double 

+ Add 

** 

*** 

2.865 

3.596 

* Multiply 

** 

** 

2.778 

4.188 Avg . 

/ Divide 

** 

** 

2.065 

3.686 3.196 

Memory Loop Access 

Times 




read 

write 

copy 


Char type 

1.394 

1.665 

2.796 


Short type 

1.381 

1.598 

2.598 

Avg. 

Long type 

1.295 

1.631 

3.080 

1.938 

Input/Output Rates 





read 

write 

copy 


Disk 

(1.121) 

1.700 

2.354 


Pipe 



1.702 


TTY 1 





TTY 1 + 2 


* 



RAM 1-byte 


2.796 



RAM 4-byte 


3.080 




Array Subscript References 

short[] long[] 

1.811 (1.623) 


Function References 

O-parameters 1-parameter 2-parameters 

functO funct(i) funct(i.i) 

1.348 1.368 1.458 Continued 


kernel (context switching) overhead 
with every floating point operation. 

Because the Altos 486 is a busi¬ 
ness system, Altos did not put in a 
socket for a floating point hardware 

The PC/AT without 
floating point hardware 
is very slow, while the 
486 is much faster. 

chip. In the benchmarks that accom¬ 
pany this article you’ll see a com¬ 
parison of the PC/AT using the 80287 
floating point chip and the Altos 
without it. As you can see, the 
80287 chip makes a big difference 
in floating point speed! If you are 
doing a large amount of floating point 
operations, then consider a different 
machine altogether (both the PC/Af 
and the 486 are weak here). 

I was surprised to see how slow 
the Altos 486 is when compared to 
the pc/at (again, see the bench¬ 
marks). The pc/at uses the 80286 
processor, running at 6 MHz, while 
the Altos 80186 runs at 8 MHz. 
Based upon the processor speeds, 
you would think the 486 would be 
faster. But the 80286 chip is such an 
improvement over the 8086 and 
80186 chips that the clock speed is 
misleading. 

Very telling are the memory ac¬ 
cess times, which are a basic mea¬ 
surement of the performance in a 
business system. The pc/at is al¬ 
most twice as fast as the Altos 486, 
comparing only memory speeds. 
Disk input/output (I/O) is also an¬ 
other important measurement. The 
PC/AT is 1.2 times faster than .the 
486 (when comparing only disk 
speed). This number is even more 
surprising when you consider that 
both machines use the same half¬ 
height, hard-disk technology. 
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ALTOS 486 VS. IBM PC/AT 



IBM PC/AT 

Altos 486 

CPU 

Intel 80286 

Intel 80186 

Clock speed 

6MHz 

8MHz 

Floating point hardware 

Not available 

Intel 80287 

Serial I/O controller 

_ 

Z80 

Internal memory—standard 

512K bytes 

512K bytes 

—maximum 

3 Mbytes 

1 Mbyte 

Hard disk—standard 

21 Mbytes 

21 Mbytes 

(formatted) 

—maximum 

42 Mbytes 

42 Mbytes 

Floppy disk 

1.2 Mbytes 

720K bytes 

Size 

21" x 17" x 6" 

17" x 15" x .5" 

Weight 

37 pounds 

20 pounds 

Performance 

excellent 

good 

Projected reliability 

excellent 

excellent 

Floating without hardware 

very poor 

good 

Floating with hardware 

excellent 

N/A 

Expansion 

good 

very poor 

Network port included 

no 

yes 

Network/Xenix compatibility 

no 

yes 

Expansion bus 

published standard proprietarv 

Expansion slots available 

5 

i 

COST 

Base Price 

$5795 

$6490 

First terminal and interface 

$525 

Included 

Expand to 5 serial ports 

$600 

Included 

Xenix 

$395 

Included 

Total 

$7315 

$6490 


Networking hardware is in¬ 
cluded as standard with the 486, and 
that’s a big advantage. On the PC/AT, 
the networking hardware costs from 
$300 to $1000 per machine. Also, 
not only is the networking software 
not integrated into the system on 
the pc/at, but IBM’s Xenix 3.0 does 
not directly support networking. 

RUN-TIME XENIX 3.0 

Nondevelopment “run-time” Xenix 
3.0 comes standard on the Altos 
486. The run-time Xenix includes 
the Xenix kernel and the basic util¬ 
ities. For an additional $1000, you 


An attractive feature of 
the 486’s version of 
Xenix is the integration 
of WorkNet into the 
disk 1/0 routines. 

can purchase the extended utilities 
package, which includes csh, vi, C 
compiler and optimizer, Source 
Code Control System, cu, and 
uucp. As you can see from the com¬ 
mand completeness test, the ex¬ 
tended utilities include a very large 
set of commands. I couldn’t run the 
command completeness test on 
the “run-time” Xenix because there 
were not enough Unix utilities for 
them to run on. For the uucp buffs 
out there, I can report that the Xenix 
3.0 uucp and cu utilities work. 
Other than networking and the limit 
on the number of users supported on 
the PC/AT, Xenix 3.0 is nearly identi¬ 
cal on the PC/AT and the Altos 486. 

Let me take a moment to let off 
a little steam on the subject of Unix 
versus Xenix. Xenix is a Unix sys¬ 
tem! The big difference is that the 
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DATES: 

December 4th & 5th, 1985 
TIME: 12:00 pm - 6:00 pm 

Palo Alto Hyatt Hotel 

4290 El Camino Real 
Palo Alto, California 


Northern California's only TWO-DAY event dedicated 
exclusively to OEMs and sophisticated end users. 

^ Featuring the latest in: 

CAD/CAM Systems Computers and Peripherals 

Graphics Systems Data Communications 

Engineering Workstations Unix 



Exhibiting Companies and Product Lines: 

AT & T Intel 

Daisy Mentor Graphics 

DEC Metheus 

Fujitsu Motorola 

IBM Perkin Elmer 


Sun Microsystems 
Tektronix 
Valid Logic 
Versatec 

and many more... 


Call or write for a complimentary invitation to: 

MUM NORM DE NARDI ENTERPRISES 
289 So. San Antonio Rd.,Suite #204 • Los Altos, CA 94022 • (415)941-8440 
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HARDWARE/SOFTWARE OVERVIEW 


Model 

Price 

(of review machine) 

Configuration 
(of review machine) 


First delivered 
Related models 

PROCESSOR 

CPU 

Cycle time 
Bus 

Cache size 

Min. memory 
Max. memory 

Floating point 
STORAGE MEMORY 
Floppy 
Winchester 


Backup 

I/O processors 
OTHER HARDWARE 
Serial ports 
LAN medium 
Protocols 

Standard software and 
development software) 

Unix version 

Shells 

Libraries 

Utilities 

Languages 


Altos 486 
$6490 

512K bytes RAM 
1-Mbyte floppy 

21-Mbyte (formatted) hard disk, 

1 LAN and 5 asynchronous serial 
ports, external disk port 

November 1984 
186, 586, and 986 


80186 

8MHz 

Proprietary 

None 

512K byte 
512K byte 

Software 

(range of available hardware) 

1 Mbyte, l l A inch, half-height 

21 Mbyte (20-Mbyte expansion was 
scheduled to become available 
June 1985 

Floppy 

Terminal I/O (Z80A) 

(expansion) 

5 standard, no expansion 
RS-422/ WorkNet 
3270, 3780 Bi-sync 
development (denote 

Xenix 3.0 

Bourne and AOE, csh available 
Standard Xenix 3.0 
Xenix extended utilities 

C, COBOL, FORTRAN, Pascal, 
BASIC are available 


Unix system is marketed by AT&T 
and Xenix is marketed by Microsoft. 
This is not to say that there are no 
differences; in fact, Xenix has many 
advantages over a straight System V 
Unix, but all this talk about Xenix 
being easier to use than Unix is a lot 


of hot air. I have used Microsoft’s 
visual shell (*vsh), and I did not like 
it; I find most of the other visual she 1 
programs easier to use. If you want 
to try a truly nice visual shell, look at 
HP’s pam. There is no essential de¬ 
ference between Xenix and Unix. I 


welcome the letters pointing out the 
differences because this will only 
prove my point. Now, back to the 
matter at hand. 

A very attractive feature of the 
Altos 486’s version of Xenix is the 
integration of WorkNet into the disk 
I/O routines. In a networked Altos 
xS6 environment, you can read and 
write files on another computer di¬ 
rectly. For example, to display a file 
stored on another machine you 
would type more @mach2/usr/ 
j ohn/his/file. 

This would cause a file named 
/usr/john/his/file to be read 
from a remote machine and dis¬ 
played on the local machine. Other 

Another feature of 
WorkNet is PC Path, 
which allows the IBM 
PC or compatible to 
share files on the Altos 
WorkNet network. 

than the fact that the file name is 
lengthened to indicate a remote ma¬ 
chine, there is no difference be¬ 
tween executing a command on 
the remote machine or on the local 
machine. 

Xenix 3.0 also supports the 
Berkeley 4.2 feature of symbolic 
links. Symbolic links and WorkNet 
combine to give you much of the 
functionality of a network file sys¬ 
tem. For example, if your account¬ 
ing system looks in a local directory 
called /usr/accounting/data 

for its data—but you want to use 
the same files on two different 
machines—you could use sym¬ 
bolic links to create a / u s r / 
accounting/data directory on 
the local machine that points at a 
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ALTOS SOFTWARE AVAILABILITY PROGRAM 


APPLICATIONS GENERATORS 
Software Express Inc. 

American Information 
Systems 


APPGEN Development System 
RediWrite 


GRAPHICS 

High Tech Marketing 
Altos 


High Tech Business Graphics 
Altograf 


VERTICAL APPLICATION 


Orion Microsystems 
ProMation 
Health America 

Advanced Business 
System 

Dickens Data Systems 
NMI Inc. 

MicroManufacturing 

MCBA 

The Computer Center 
Clinical Data Design 
The Computer Center 
NMI Inc. 

PAS Inc. 

Spectra Data Systems 
Romax Computers 
NMI Inc. 

Orion Microsystems 
Software Solutions 
Tracline 
SRD Inc. 

TCF Software 
NFP Management 
Systems 
Holm-Dietz 

WORD PROCESSING 

Altos (Uniplex) 

Horizon 
SofTest Inc. 

OFFICE AUTOMATION 

Altos 

Altos 

SPREADSHEET 

Altos 

(MultiPlan) 


GLOWS (client accounting) 

The Contractor’s Edge 
Patient Management System 
(dental and medical) 

EasyPost System (insurance) 

ALOT (Automated Law Office Tool) 
Magazine Circulation Fulfillment 
Manufacturing Control 
System-MCS-3 

Manufacturing And Distribution 

System 

Club Manager 

MDX System (medical) 

MUNIS (municipal goverment) 
Personnel Searcher 
Rx-II (pharmacy) 

Property Management System 
Uni-Max Retailer 
Customer Profile 
GLOWS Pratice Management 
FACTS (wholesale distribution) 
Wholesale and Retail Accounting 
ADAM Auto Repair Management 
Client Ledger 

Non-Profit Fund Accounting 
Farm Management System 


Executive Word Processor 
Horizon Word Processor 
Lex-86 Word Processor System 


ABS-86 Business Solution 
AOE (Altos Office Executive) 


Altos Financial Planner 


DATA COMMUNICATIONS 
SofTest Inc. SofGram 


Continued 


/u 5 r/ac coun t i ng /da t a direc¬ 
tory and the shared machine. 

In this way all file references 
would automatically reference the 
single shared files. This is not as 
clean or as flexible as a true net¬ 
worked file system, but it should 
work for many applications. A single 
shared printer could be implemented 
by making a symbolic link for all ma¬ 
chines to a shared /usr/spool/ 
lpd directory. 

Another feature of WorkNet is 
pc Path, which allows the ibm pc or 
compatible to share files on the Altos 
WorkNet network. This is done by 
creating a special pc file under Xenix 
that contains the image of an ibm pc 
floppy or hard disk. This will allow 
people who have PCs to share the 
486 hard disk while still working with 
pc-dos. Altos also provides a free 
Altos III terminal emulation program 
for the IBM pc. 

When you compare the version 
of Xenix 3.0 on the Altos 486 with 
that on the PC/AT, the Altos 486 is a 
winner, but not a big winner. The 
486 has three advantages. First, you 
can put four users on the 486, ver¬ 
sus only three on the PC/AT. Second, 
the networking is integrated into 
Xenix on the 486, but it is ignored on 
the PC/AT. These points will be very 
important to people who need them. 
And third, PC Path will sell a number 
of systems because it creates a 
bridge between pc-dos and Unix. 


OTHER SOFTWARE 

We are still hearing that the Unix 
system does not have any applica¬ 
tions software, but when you con¬ 
sider the software available for the 
Altos x86 machines, you should for¬ 
get this nonsense It’s all disinfor¬ 
mation foisted on the world by pc 
propagandists. The list of software 
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AVAILABILITY CONTINUED 


DATA MANAGEMENT 
RDS Inc. 

SMC Software Systems 
Unify Corporation 


Informix C-ISAM 
Thoroughbred IDOL 
Unify 


GENERAL BUSINESS ACCOUNTING 


Open Systems 
Americal Business 

SvQtprrm 

RealWorld Software 
SMC Software Systems 
Software Express Inc. 
NMI Inc. 

OPERATING SYSTEM 

Altos/Microsoft 

Altos/Microsoft 

LANGUAGES 

Ryan-McFarland 

Micro Focus 

Digital Research 

SMC Software Systems 

Microsoft 

Microsoft 

Microsoft 

Microsoft 

Omtool 

COMMUNICATIONS 

Altos 

Touchstone Software 

Touchstone Software 

Altos 

Altos 

Altos 

Altos 

Altos 


Accountant 

BACS Accounting System 

RealWorld Accounting 
Thoroughbred Accounting System 
Financial Series 
Complete Accounting 


Xenix Run Time 
Xenix Extended Utilities 


RM/COBOL 
LEVEL II CIS COBOL 
CBASIC-16 
Business Basic III 
MBASIC 
MS Pascal-86 
MS FORTRAN-86 
MS COBOL-86 
SOFTBOL 


WorkNet 
PCworks 
MIMIX 
PC Path 

2780/3780 IBM bisync 
3270 IBM bisync 
3270 SNA/SDLC emulator 
X.25 packet switching 


packages available for the Altos 486 
includes sixteen vertical applica¬ 
tions, nine compilers/interpreters, 
three database management pack¬ 
ages, three word processors, and 
more. This should allow end-users 
to choose the software package that 
most closely fits their needs. 

Included with the machine I 
reviewed was the integrated Altos 
Office Executive (aoe) office auto¬ 
mation system. AOE combines a data 


manager, spreadsheet, word pro¬ 
cessor, and electronic mail program 
into one semi-integrated package. 
With aoe, you can create a mass 
mailing using data from the data¬ 
base, and you can include data from 
the database into a spreadsheet, etc. 

Altos made AOE by taking thre > 
existing packages and writing inter¬ 
faces between them. The spread¬ 
sheet is Multiplan from Microsoft; 
the data manager is File-it from 


Relational Database Systems; and 
the word processor is Uniplex from 
Redwood Software of the UK (known 
as Uniplex Integration System here 
in the U.S.). Unlike other similar inte¬ 
gration efforts, Altos' interface be¬ 
tween these different packages is 
fairly clean. One sign of just how 
clean is the fact that you can “mail- 
merge” a form letter with a File-it 
database. 

I have worked with Multiplan 
and File-it before, but the word pro¬ 
cessor was new to me. I liked the 
combination of function keys and 
menus, which made Uniplex very 
easy to use and extremely powerful. 

I found myself wishing that it worked 
on my day-to-day computer. 

There are some weaknesses in 
Uniplex, to be sure, but these are 
minor and repairable. One thing I 
found surprising is that you could not 
nest special printing features (you 
can’t get boldface underline, for ex¬ 
ample). Also, the spelling checker 
has very few options. When the soft¬ 
ware finds a misspelling, it brings up 
only two choices: You can accept the 
spelling, or you can change the spell¬ 
ing. With more advanced spelling 
checkers, you have many choices, 
including having the program give 
you a menu of possible correct 
spellings. 

rds’ File-it is not a database 
manager simply because you cannot 
create cross database joins, but it is 
one of the easiest to use and one of 
the simplest data management tools. 
What it lacks in power, it more than 
makes up for in simplicity and ease of 
use. I have given this tool to tech¬ 
nophobes and have found them using 
it 30 days later to keep track of all 
sorts of things. More powerful data¬ 
base management systems are often 
intimidating. 

I don’t have too many good 
things to say about Multiplan, other 
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ALTOS ADDS HIGH-END UNIT TO x86 LINE 


As we were going to press, Altos Computer Systems Inc. ex¬ 
panded its x86 line of Unix system supermicros with the Altos 
3068, which accommodates up to 30 users and a wide range of 
system options. The 3068, designed for original-equipment 
manufacturers (OEMs) and major accounts, incorporates Unix 
System V and the 32-bit Motorola 68020 microprocessor. 

The 3068 is designed to run as a stand-alone, general- 
purpose computer or as a node in a distributed network. The 
3068 can be networked with all other Altos multiuser systems 
via the Altos WorkNet local-area network, and with main¬ 
frame computers via 3270 Bysync, SNA, X.25, and 3780 com¬ 
munications options. With Altos PC Path attached to WorkNet, 
the 3068 can act as a file server and communications gateway 
for personal computer users. 

The Altos 3068 supermicrocomputer’s base configuration 
includes 1 Mbyte of random-access memory (RAM), a 20-Mbyte 
hard disk, and a 1.2-Mbyte floppy-disk drive supporting up to 
10 users. Users can expand the main memory to 16 Mbytes in 
4-Mbyte increments. Hard disks can be upgraded to 
240 Mbytes (unformatted) in 20-, 60-, or 80-Mbyte incre- 
ments. A streaming magnetic tape unit, with up to 60 Mbytes 
of backup storage, is also available with the 3068. 

The modular systems design includes eight board slots, 
with four available for custom configuration. Additional 
boards can be added or replaced, at user discretion, depending 
on the need for additional users, memory ports, or proprietary 
boards. J 

J he ^ nix System V operating system available for the 
3068 supports demand-paged virtual memory with lK-byte 
page size, allowing programs that exceed physical memory to 
be run on the system. 

The 3068 is scheduled to become available in July on a 
worldwide basis. Base configuration price is under $7000 in 
OEM quantities. 


than that it runs on a wide range of 
computers and that it is a spread¬ 
sheet. What I want to know is, when 
will some of the better micro¬ 
computer spreadsheets move to 
Xenix/Unix. 

CONCLUSION 

I really don’t know how the Altos 
486 will do against IBM’s PC/AT; it’s 
too early to predict, for one thing. 
Currently, Altos is selling the 486 
quite well against the pc/at, but 
there is a maxim in the computer 
world: To compete with IBM, you 


have to be half the price, be twice as 
good, or sell something else. It is 
clear from my review that the Altos 
486 is neither twice as good as the 
PC/AT nor half the price. But that 
does not mean that it will fail. 

Perhaps Altos is selling an 
integrated, low-hassle, low-mainte¬ 
nance, Xenix business computer. I 
am not sure what IBM is selling with 
the PC/AT. But with all the options 
and add-on hardware and confu¬ 
sion about pc-dos and Xenix, the 
pc/at is not a low-hassle, low- 
maintenance, low-priced multiuser 
microcomputer. 


I do have a simple suggestion 
for Altos: Why not include with the 
486 all the basic business soft¬ 
ware—a spreadsheet, word pro¬ 
cessor, data manager, and account¬ 
ing system. This would make the 
Altos 486 the Osborne-1 of the mul¬ 
tiuser microcomputer world. □ 


Bruce Mackinlay, Unix/World’s gonzo 
reviewer and editor-at-large for reviews, 
is vice president of research and devel¬ 
opment at WMZ /Novatech, Concord, 
Calif His last work for this magazine, 
a review of the Pyramid 90x supermini, 
appeared in the May 1985 issue . 
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BY THOMAS BUTLER AND 
LISA KENNEDY 


THE AT&T UNIX 
SYSTEM 


FACILITY 


help 


T he new Unix* system help 
facility provides quick, easy 
access to information about 
a^Mthe Unix system. The facil¬ 
ity consists of five Unix commands— 
help, starter, glossary, 
usage, and locate —each of 
which is the name of a separate 
module of the facility. 

Each module contains a differ¬ 
ent kind of information: 

(one) help is the top-level 
menu interface to the entire facility. 
Through it, all other modules can be 
entered. 

(two) starter contains infor¬ 
mation about the local Unix system 
and general information for begin¬ 
ning system users. 

(three) glossary contains defi¬ 
nitions of terms and symbols im¬ 
portant for the Unix system. 

(four) usage contains detailec 
information about specific Unix sys¬ 
tem commands. 

(five) locate is a commanc 
“thesaurus.” It identifies Unix sys¬ 
tem commands related to keywords 
submitted by the user. 

The facility is quite flexible, and 
most information can be accessed in 
several different ways, depending on 
the proficiency and preference of the 
user. All information in the facility 
can be retrieved by typing “help” at 


shell command level and then enter¬ 
ing menu choices until the desired 
information is reached. 

Users can also use individual 
modules of the facility by typing the 
name of the module at shell com¬ 
mand level, thereby avoiding the use 
of some menus. The glossary, 
locate, and usage commands also 
accept command line arguments so 
that users can enter all required in¬ 
formation on the command line and 
directly retrieve the information 
they desire. 

The facility also contains a 
mechanism to collect and store data 
about its use as well as a set of soft¬ 
ware tools for command developers 
and system administrators who wish 
to modify the help database. 

Much of the data contained in 
the facility was collected directly by 
questionnaires and surveys sent to 
Unix system users. The user inter¬ 
face of the facility was designed 
with special care to be terse enough 
for experienced users but simple 
enough for beginners. 

The first release of the Unix 
system help facility is an initial 
step toward providing a comprehen¬ 
sive, easy-to-use interface between 
users and all system documentation. 
Further expansion and refinements 
of the facility are now under way. 
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The wide proliferation of the 
Unix operating system is a strong 
indicator of its power and ease of use 
for programmers and other com¬ 
puter professionals. It is not, how¬ 
ever, always the easiest system for 
beginners to use. The shortcomings 
of the Unix system have been widely 
discussed and need no further elabo¬ 
ration here. One early, and obvious, 
step we can take toward making the 
Unix system easier to learn is to give 
its users a helpful on-line assistance 
facility. This article describes the ini¬ 
tial help facility we have designed 
to fill this need. 

The first section of the article 
briefly describes a prototype facil¬ 
ity that we built and the reasons 
we built it. The next section de¬ 
scribes the initial set of require¬ 
ments adopted for the first version 
of the facility. This is followed by a 
discussion of data gathering to col¬ 
lect information for inclusion in the 
facility and, finally, by a discussion of 
the human interface we designed. 


THE PROTOTYPE 

Our first decision was to build a pro¬ 
totype of the facility and to throw it 
away at the end of the proposed 
seven-month development period. 
While this may seem an odd way to 
begin a development project with 
short deadlines, the idea did not 
originate with us (Brooks, 1975), 
and the prototype approach has 
several distinct advantages. The 
most important of these are the fol¬ 
lowing: the prototype could be im¬ 
plemented quickly; the code need 
not be optimized until we are sure 
we have designed the system we 
really want; and the prototype could 
be tested with real users and revised 
before it is actually released as a 
Unix system product. 


The prototype we designed and 
implemented was quite small, but it 
allowed us to do the following: evalu¬ 
ate the user interface to the facil¬ 
ity; evaluate our data-collection pro¬ 
cedures; evaluate the data collected 
to populate the facility; and evaluate 
the development method. 


REQUIREMENTS 
AND DESIGN 

The Unix system help facility is 
an interactive utility available at shell 
command level. It allows users to 
retrieve a variety of information 
about the Unix system while they 
are working on-line and to retrieve 
that information easily and con¬ 
veniently. The facility consists of 
the top-level interface help and 
four major modules —starter, 
glossary, usage, and locate. 

The four modules provide the 
following information, respectively: 
(one) general information about the 
local Unix system; (two) a glossary 
of technical terms often used in re¬ 
lation to the Unix system; (three) in¬ 
formation about the usage of specific 
commands, including examples; and 
(four) a means of identifying un¬ 
known Unix system commands us¬ 
ing keywords related to the desired 
command functions. 

It is easiest to think of the h e 1 p 
facility as a tree structure, with the 
top-level help menu interface at the 
root of the tree and the other four 
modules subordinate to it. Individ¬ 
ually, the four modules are all quite 
different in their structure, and each 
of them will be described separately. 

The starter module can be 
thought of as a sort of formatted 
bulletin board. It contains general in¬ 
formation for users, much of which 
is specific to the local system where 
the facility is installed. In Release 1 


of help, s tarter includes a list of 
the Unix system commands and 
terms we believe new users should 
learn first; a list of education centers 
offering Unix system training; a list 
of important Unix system docu¬ 
ments for beginners; a list of on-line 
teaching aids and tutorials available 
for the system; a set of local envi¬ 
ronment information, including the 
system administrator’s name and 
phone number, the name of the sys¬ 
tem, and the type of processor run¬ 
ning the system. 

Users retrieve information 
from these starter components 
by selecting the appropriate cate¬ 
gory on a menu. The user interface 
for the facility will be described in 
greater detail later in the article. 

The glossary module pro¬ 
vides definitions for many common 
Unix system terms and symbols. 
Many of the definitions contain ex¬ 
amples to illustrate the concepts be¬ 
ing defined and references to related 
Unix system commands. The first 
screen of this module includes a 
complete list of the terms and sym¬ 
bols supported. Like starter, the 
glossary module is mainly menu 
driven. 

The usage module gives users 
specific information about individual 
Unix system commands. One part 
of usage provides a syntax sum¬ 
mary and a short paragraph de¬ 
scribing the action and uses of the 
command. Much like the synops i s 
section of the Unix System V User 
Reference Manual, the syntax sum¬ 
mary includes a list of allowable 
options for the command and a com¬ 
mand line showing the relative posi¬ 
tions of the command name, its 
options, and its arguments. 

The two other parts of usage 
include a list of all options for the 
command and an explanation of 
each, and examples of typical com- 
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mand lines using the command and 
an explanation of what each com¬ 
mand line does. Users move through 
these different sections of usage by 
making menu selections. 

The final module, locate, ac¬ 
cepts from the user a set of key¬ 
words related to the work the user 
wants to do. It then identifies a set of 
Unix system commands likely to be 
helpful in doing this work. For exam¬ 
ple, if users are seeking a command 
to print the contents of a file, they 
might enter the keywords “file,” 
“print,” “contents,” and “output," or 
some subset of this list. 

The keywords themselves are 
entirely free form; users can submit 
any keyword they think is related 
to the work they want to do. The 
locate module keeps a quite large 
set of keywords on file for each of 
the Unix system commands it sup¬ 
ports. After accepting the key¬ 
words, locate checks the keyword 
list for each command and returns 
the names of all commands having a 
keyword on file that matches any of 
those entered by the user. 

After identifying a command, 
users can directly access the de¬ 
tailed command information in the 
usage module. If they find that 
the command they selected is not 
the one they need, they can return 
directly to the list produced by 
locate and make another selec¬ 
tion. As with the other modules, 
choices are presented and input is 
solicited using menus. 

In addition to these four mod¬ 
ules, help contains a logging mech¬ 
anism to collect and store data about 
its use. It also has a set of software 
tools for use by command devel¬ 
opers and system administrators 
who want to add information about 
their local system, add data for local 
commands, or otherwise modify the 
help database. 
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These additional features are 
available through a separate com¬ 
mand called helpadm, which is 
provided with the help facility. Us¬ 
ing this command, system admin¬ 
istrators can turn on or turn off the 
logging of usage data on the facil¬ 
ity; and both developers and admin¬ 
istrators can add, modify, or delete 
starter information, glossary 
definitions, the descriptions, option 
descriptions, and examples in 
usage, and the keyword informa¬ 
tion used by locate for each com¬ 
mand. It should be possible, for ex¬ 
ample, to use helpadm to insert 
foreign language text and data into 
the help database. 

DATA GATHERING 

Some of the data contained in the 
facility was obtained through con¬ 
sulting standard reference docu¬ 
ments for the system. For example, 
this is the way we obtained all the 
command syntax summaries in the 
usage module. Also obtained this 
way were information about Unix 
system training locations, Unix sys 
tern beginner documentation, the 
names of currently available on-line 
teaching aids, and the definitions of 
terms and symbols. 

All the remaining information in 
the system was obtained primarily 
through questionnaires and survey 5 
administered to a controlled mixture 
of experienced and inexperienced 
Unix system users within at&t Be 1 
Laboratories. 

After a substantial amount of ir - 
formation was collected with the 
questionnaires and surveys, we co - 
lated the results, checked the data 
for correctness, and edited all the 
information for consistency. The im¬ 
portant difference between our pro¬ 
cedure and the usual one in a design 
effort of this type is that, rather the n 


relying only on the intuitions and 
judgments of those involved with de¬ 
signing and developing the facility, 
the intuitions and judgments of a 
large sample of both experienced 
and inexperienced users were col¬ 
lected and considered when we de¬ 
cided what to include and what to 
exclude from the system. 

The importance of the data ob¬ 
tained through surveying real Unix 
system users cannot be overem¬ 
phasized. The contents of all of the 
following were primarily the result of 
input from Unix system users: the 
command descriptions in the usage 
module; the examples of typical us¬ 
age for each command in the usage 
module; the command keyword list 
placed on file for use by the locate 
module; and the specific set of Unix 
system commands included in the 
suggested “minimal” set given in the 
starter module. 

In addition, all our decisions 
about precisely what sorts of infor¬ 
mation to include in the star ter 
module were strongly influenced by 
user input from surveys. This ap¬ 
proach is quite different from the 
usual strategy of relying on de¬ 
signers’ intuitions for the first ver¬ 
sion of a system and then testing 
the users’ reactions to it later. So 
far, we have found it to be a pleasant 
change. 

THE HUMAN INTERFACE 

Designing the user interface for 
something like a help facility is frus¬ 
trating. On one hand, the facility 
must be simple enough for a begin¬ 
ning user; on the other hand, the 
system must be terse enough that 
expert users won’t be irritated by 
verbose guidance and instruction. 
We have tried to consider both popu¬ 
lations of users in the present design 
and have produced a flexible, vari- 
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APPLICATIONS 

SOFTWARE 

TOUCHSTONE CONNECTS 
UNIX SYSTEMS, MACs 

Touchstone Software Corp. has re¬ 
leased MacLine, a Macintosh net¬ 
working software package. With the 
MacLine terminal emulator, users 
can connect Apple Macintosh com¬ 
puters to a variety of other comput¬ 
ers and information services. 

When MacLine is used with the 
other Connectables network prod¬ 
ucts, pcworks and UniHost, the 
Macintosh can transfer all types of 
files to and from Unix systems or 
pcs, exchange mail with other sys¬ 
tem users, and access a remote 
printer or disk. 



TouchStone Software Corp. s MacLine 
networking software package 


MacLine software is priced at 
$145. UniHost for Unix systems 
costs $295, and pcworks costs $195. 

For more information, contact 
TouchStone Software Corp., 909 
Electric Ave., Suite 207, Seal Beach 
CA 90740; 213/598-7746. 

Please circle Reader Service Number 160. 


WINDOW SYSTEM 
INTRODUCED FOR XENIX 

Viewnix windowing interface for 
Unix system-based microcomputers 
is now available from Five Paces 
Software Inc. The product is being 
shipped for the IBM pc/at and XT run¬ 


ning the Xenix operating system and 
will soon be offered on other Unix 
systems that employ memory- 
mapped displays, the company said. 

Viewnix allows the user to 
configure up to 10 windows on the 
screen of the pc/at, each of which 
can contain any standard Xenix ap¬ 
plication. The windows can be ex¬ 
panded, contracted, or moved about 
the screen to suit the user’s specific 
needs. In addition, a cut-and-paste 
capability is provided to facilitate the 
integration of data between different 
applications. 

Viewnix offers a programming 
interface that will allow applications 
to take control of the windows in 
which they are run. The system al¬ 
lows applications to write directly to 
the window memory buffers so that 
programs running on the memory- 
mapped console will not have to em¬ 
ploy the slow, character-at-a-time 
video output associated with Unix 
systems. 

Viewnix retails for $249, with 
discounts available to volume pur¬ 
chasers; UniMove and UniLink are 
each priced at $149. 

For more information, contact 
Five Paces Software Inc., 9635 
Wendell Rd., Dallas, TX 75243; 
214/340-4933. 

Please circle Reader Service Number 161. 


NEW ACCOUNTING 
SOFTWARE FROM AMI 

Accountants Microsystems Inc. 
(ami) has released Datawrite Cor¬ 
porate General Ledger. The new 
software operates under Xenix or 
MS-DOS on most business micro¬ 
computers and can be tailored for 
virtually any industry or firm. 

The software’s flexibility de¬ 
rives from the Datawrite proprietary 
Matrix Report Writer, essentially 
two report writers in one. The first 
allows the user to specify any ac¬ 


count in any order and to change the 
account description without affecting 
the basic chart of accounts. The sec¬ 
ond report writer lets the user set 
columns, headings, subtotals, and 
totals in any format for management 
and financial reports. Matrix Report 
Writer is menu driven rather than 
chart driven. 



AMI accounting software 


Corporate General Ledger re¬ 
tails for $2995 and is available from 
ami’s direct sales force and its deal¬ 
ers and agents. 

For more information, contact 
Accountants Microsystems Inc., 
3633 136th Place S. E., Bellevue 
WA 98006; 206/643-2050. 

Please circle Reader Service Number 162. 


NEW VUE PORTS 
FROM NIS 

National Information Systems has 
announced that VUE, a project man¬ 
agement system available for Unix 
system processors, is now available 
on a variety of computers, includ¬ 
ing Convergent Technology’s Mini¬ 
fy rame, Gould, and nbi, all running 
under the Unix system. 
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THE MOST 


NAME . 

WDELYUSH) 

MTEGRATED 
OFFKEAUIQ „ 

SOFTWARE FOR 
UNIX SYSTEMS. 

"UMPUXII" 

YOU'VE GOT IT! 


User satisfaction is the primary reason no other product 
can make this claim. Already in its second generation, 
UNIPLEXII offers features designed to meet .the require¬ 
ments of the most demanding user. 

The beauty of UNIPLEX II is its simplicity. One 
personality and one command structure throughout 
the program provide an ease of use never before 
experienced with UNIX application software. 

UNIPLEX II integrates sophisticated word processing, 
spreadsheet, and relational database applications into a 
powerful one-product solution. 

UNIPLEX II uses termcap, so it can run on virtually 
any computer terminal. “Softkeys” allow the user 
to define function keys which are displayed on the 
25th line of most terminals to provide versatility and 
ease of use. 

All this at a price you’d normally pay for a single 
application software package. 


UNIPLEX II is available immediately from UniPress 
Software, the company that’s been at the forefront of 
quality UNIX software products longer than anyone else. 
OEM terms available. Mastercard and Visa accepted. 
Call Today Once you’ve got it, you’ll see why 
UNIPLEX II is the most widely used integrated office 
automation software for UNIX-based systems. 


08 i: 


Write to: 
Edison, NJ 
or 201-985-8 
Distributor: 
Distributor: N 


Please circle Ad No. 77 on inquiry card. 


LfniPress Software, 2025 Lincoln Hwy., 

517 or call: 1-800-222-0550 (outside NJ) 
000 (in NJ); Telex: 709418. Japanese 
oftec, Telephone: 0480 (85) 6565. Swiss 
lodulator SA, Telephone: (031) 59 22 22. 


JniPress Software 


t>ur Leading Source for UNIX Software 


I MX u atrademark of AT&T Ml Uh r*.r.n Inlplex II is a trademark of (implex Integration Systems 
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VUE allows either i-j or prece¬ 
dence notation and uses the critical 
path method of scheduling. Fourteen 
reports are standard, including 
printer graphics versions of bar 
charts and network diagrams. Func¬ 
tions include sorting on the desired 
field, specifying a time window, pick¬ 
ing selected material for reporting, 
and summarizing for less detailed 
reporting. 

VUE now runs on the AT&T 
3B series, Convergent Technology 
MegaFrame and MiniFrame, dec 
10/20, vax, and PDP-11, Fortune, 
Gould, Honeywell dps-6 and -8, HP 
3000, ibm mainframe vm/cms, nbi, 
Perkin Elmer, and Zilog S8000. 
The user interface remains the 
same across the entire selection of 
computers. 

Price ranges from $2995 for 
supermicro versions to $20,000 for 
large mainframe versions. 

For more information, contact 
National Information Systems, 
20370 Town Center Lane, Suite 
130, Cupertino, CA 95014; 408/ 
257-7700. 

Please circle Reader Service Number 163 . 


BIG 8 ACCOUNTING 
RUNS UNDER UNIX 

A multiuser business accounting 
software package designed to run 
under the Unix system, MS-DOS, and 
ms-dos networks is now available 
from Modern Technologies Inter¬ 
national Inc. (ModTech). 

The Big 8 Accounting Series 
from ModTech eliminates the need 
to purchase a single-user product for 
current needs and then replace it 
with a multiuser product as the com¬ 
pany grows. 

The series offers five inte¬ 
grated, menu-driven accounting 
packages designed to satisfy busi¬ 
ness accounting needs, including 
inventory control, general ledger, 


accounts receivable, accounts pay¬ 
able, and payroll. 

The Big 8 offers this multiuser 
capability on Unix Systems III and 5, 
Version 7, Xenix, Venix, and pc-ix. 

Retail price per module is $695 
for dos and $895 for the Unix sys¬ 
tem. ModTech is distributing the Big 
8 Accounting Series through value- 
added dealers, microcomputer retail 
chains, and OEMs. 



The Big 8 from Modern Technologies 


For more information, contact 
ModTech Inc., 656 Bair Island Rd., 
Suite 302, Redwood City, CA 
94063; 415/367-6855. 

Please circle Reader Service Number 164 . 


CREATIVE APPLICATIONS’ 
ACCOUNTING SOFTWARE 

Creative APLications Inc. has ex¬ 
panded its oil and gas accounting 
software to run under the Unix oper¬ 
ating system. 

This means that smaller inde¬ 
pendents can start out with a low- 
cost but single-user computer and 
upgrade to a multiuser system later 
without having to start over with 
new software. 

Energy Plus supports the ibm 
PC/AT (using Xenix) and 9000, the 
Hewlett-Packard ipc and 9000, For¬ 
tune, Wicat, Cadmus, Callen, and 


others. In the future, the software 
will also support other supermicro 
and minicomputer systems, includ¬ 
ing hardware from at&t, Data Gen¬ 
eral, and Digital Equipment Corp. 

The system includes features 
to help first-time computer users, 
such as complete on-line documen¬ 
tation and “Help” keys that enable 
users to get on-line assistance while 
in the middle of any program. 

For more information, contact 
Creative APLications Inc., 2525 S. 
Wadsworth Blvd., Suite 206, Lake- 
wood, CO 80227; 303/985-4465. 

Please circle Reader Service Number 165 . 


HARDWARE 
AND SYSTEM 

DEC ENHANCES ULTRDC-32 
AND PRO/VENIX 

Digital Equipment Corp. has an¬ 
nounced a series of enhancements 
for two Unix-based operating sys¬ 
tems, Ultrix-32 and Pro/Venix. 

Version 1.1 of Ultrix-32 pro¬ 
vides increased support for the vax 
family of computers and broader 
compatibility with System V. The 
Ultrix-32 operating system is an 
interactive, virtual-memory, time¬ 
sharing Unix system that runs on 
members of Digital’s vax family of 
computers. 

Version 2.0 of Pro/Venix allows 
applications designed to run under 
System V to be ported to Pro/Venix 
with little or no modification. Ether¬ 
net communications and support for 
the Laboratory Interface Module on 
the Pro under Pro/Venix were also 
announced. 

Prices on the Ultrix-32 Version 
1.1 vary according to the hardware, 
number of users, package, and ser¬ 
vices chosen. 

Pro/Venix Version 2.0 is avail¬ 
able in the base system package, 
priced at $495, which includes edi- 
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TEXT EDITING 


Another in a series of 
productivity notes on 
UNIX " software 
from UniPress. 


Subject 
full sen i 


Multi-wi 
provider. 
Several 
taneoudji 
grammi 
The 
languat 
bility to 


! built 


below, full screen editor 
extraordinary text editing, 
files can be edited simul- 
y, giving far greater pro- 
i Ipg productivity than vi. 

’-in MUSP programming 
ide provides great extensi¬ 
le editor. 


Multi-window, 
en editor. 


New Features: 

■ EMACS is now smaller and 
faster. 

■ Sun windows with fonts and 
mouse control are now provided. 

■ Extensive on-line help for all 
commands. 

■ Overstrike mode option to 
complement insert mode. 

■ New arithmetic functions and 
user definable variables. 

■ New manual set, both 
tutorial and MUSP guide. 

■ Better terminal support, 
including the option of not using 
unneeded terminal drivers. 

■ EMACS automatically uses 
terminal's function and arrow 
keys from termcap and now 
handles terminals which use 
xon/xoff control. 

■ More emulation- T0PS20 for 
compatibility with other EMACS 
versions, EOT and simple 
WordStar ™ emulation. 

Features: 

■ Multi-window, full screen 
editor for a wide range of UNIX, 
VMS '“ and MS-DOS '“ machines. 

■ "Shell windows" are sup¬ 
ported, allowing command 
execution at anytime during 
an edit session. 

■ MLISP m programming 
language offers extensibility for 
making custom editor com¬ 
mands! Keyboard and named 
macros, too. 


trademarks ol Jnfiicss EMACS & MUSP, Unfins ,s Software. Ik UNIX A 
At&l 38 Sena AIM Bell laboratories. VAX/VMS A Rainbow 100 > Digital 
Equipment Con . MS DOS. Microsoft Cotp, WoidStat. MicroPro 
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■ "Key bindings" give full 
freedom for defining keys. 

■ Programming aids for C, 
Pascal and MUSP: EMACS 
checks for balanced parenthesis 
and braces, automatically indents 
and reformats code as needed. 

C mode produces template of 
control flow, in three different 
C styles. 

■ Available for the VAX '“ 

(UNIX and VMS), a wide range 
of 68000 machines, IBM-PC',“ 
Rainbow"" 100+, and many more. 


Price: 

Binary Source 

VAX/UNIX 

$995 

VAX/VMS 

$2500 7000 

68000/UNIX 

395 995 

MS-DOS 

"Call for terms 

475 


For more information on these 
and other UNIX software 
products, call or write: 
UniPress Software, Inc., 

2025 Lincoln Hwy., 

Edison, NJ 08817. 

Telephone: (201) 985-8000. 
Order Desk: (800) 222-0550. 
(Outside NJ). Telex: 709418. 
Japanese Distributor: 

Softec 0480 (85) 6565. 
European Distributor: 
Modulator SA (031) 59 22 22. 

OEM terms available. 
Mastercard/Visa accepted. 
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tors, serial communications, text 
processing, a basic interpreter, and 
graphics utilities; and the Software 
Development Package, priced at 
$600, which includes the C, 
fortran, and Pascal compilers; 
sees; and the more popular Unix 
system support interested in the 
software development package. 

For more information, contact 
Digital Equipment Corp., Maynard, 
Mass. 

Please circle Reader Service Number 166. 


SERIES 8000 FAMILY OF 
COMPUTER SYSTEMS 
FROM SMS 

Scientific Micro Systems’ sms 8000 
Model 40 is a Multibus-compatible, 
Winchester-based microcomputer 
system available in a wide variety of 
configurations. All versions include 
the system enclosure, a choice of 
fixed and removable peripherals, 
8086/80286 processors, and up to 6 
Mbytes of main memory. 

The sms 8000 will run all sys¬ 
tem and application software devel¬ 
oped for Intel’s RMX 86 or Xenix 
operating systems, as well as 
cp/m-86. A removable 10-Mbyte 
Winchester cartridge drive may also 
be included as either a system disk 


or backup device. In addition, a high¬ 
speed streaming tape drive may be 
packaged as a backup device. 

The sms 8000 Model 40 offers 
single or dual 5Vi-inch Winchester 
drives with capacities of 12 to 280 
Mbytes. List price for the SMS 8000 
Model 40 starts at $5900 in quantity, 
complete with foundation module 
and one serial port, 12-Mbyte 
Winchester, SVi-inch 7000K-byte 
floppy, 8086 CPU, and 512K bytes of 
main memory. 

For more information, contact 
SMS, 339 N. Bernardo Ave., Moun¬ 
tain View, CA 94043; 415/ 

964-5700. 

Please circle Reader Service Number 167. 


SYSTEMS SOFTWARE 

UNIX SYSTEM V FOR 
INTEL’S 80286 

AT&T’s Unix System V, Release 2, 
operating system is now available for 
use with Intel’s 80286 micro¬ 
processor. 

The 80286 microprocessor’s 
on-chip memory management and 
protection eliminate complex repro¬ 
gramming of the Unix system kernel 
when Unix System V is transported 
from one 80286-based computer 
system to another. 


Many independent software 
vendors support the 80286 micro¬ 
processor with enhanced versions of 
System V/286. OEM’s can choose 
among the UniPlus operating system 
by UniSoft Systems, the iN/ix by 
Interactive Systems, and System 
V/286, Release 2, by Microport 
Systems (a spinoff from Digital 
Research Inc.). 

at&t will market the source- 
code product to resellers building 
hardware and software products 
around System V/286. It is priced at 
$43,000 for the initial host 286 sys¬ 
tem and at $16,000 for each addi¬ 
tional host. 

For more information on the 
System V/286, contact Intel Corp., 
Literature Dept. W-193, 3065 Bow¬ 
ers Ave., Santa Clara, CA 95051; 
408/987-5084. 

Please circle Reader Service Number 168. 


MODULA-2 FOR THE 
UNIX SYSTEM 

A compiler and run-time library for 
the Modula-2 language has been 
developed for Unix systems based 
on the Motorola 68000 series of mi¬ 
croprocessors. With Modula-2/68, 
it is now possible to use the Modula- 
2 programming language for all types 
of Unix programming. It can be used 
by itself or with C and Pascal to im¬ 
plement complex system program¬ 
ming applications. 

With Modula-2/68, program 
modules can be compiled separately. 
An executable process can then be 
built by linking with other previously 
compiled program modules or by 
linking with library procedures writ¬ 
ten in C or Pascal. Modula-2 pro¬ 
cedures can be included in the stan¬ 
dard object libraries for use by 
programs written in C or Pascal. For 
M68000 application the Modula-2 
programs can be output in the stan¬ 
dard Motorola S-record format. 
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Modula-2/68 is now available 
for unos and 4.2BSD Unix systems. 
Manufacturers of Unix systems 
based on the M68000 are being en¬ 
couraged to add the Modula-2/68 
imf lementation of Modula-2 to their 
line of supported programming lan¬ 
guages. Modula-2/28 is also avail¬ 
able as a cross-compiler for use with 
the vax/vms operating system. List 
price for UNOS version is $495. 

For more information, contact 
Djavaheri Bros., 697 Saturn Court, 
Foster City, CA 94404; 415/ 

66 : - 6868 . 

Please circle Reader Service Number 169. 


C68 FROM 
INFORMATION 
PROCESSING 
TECHNIQUES CORP. 

C68 from Information Processing 
Techniques Corp. (IPT) is a develop¬ 
ment tool for software designers 
targeting development to Motorola 
68000-based machines. Four ele¬ 
ments comprise a C cross-compiler: 
a cross-compiler that generates 
68000 code from C source, a cross- 
assembler to produce relocatable bi¬ 
nary files that can be linked together 
with the linker, a cross-linker to link 


relocatable binaries that may be run 
on any 68000-based machine, and a 
librarian that produces libraries for 
use with the linker. 

C68 also allows programmers 
to develop software for Motorola 
68000-based machines on a variety 
of other systems. 

C68 is available for Data Gen¬ 
eral (dg) computers running rdos, 
aos, eclix, and aos/vs, as well as on 
DEC computers running VMS or the 
Unix system. There is a one-time 
license fee of $7000. 

Other C tools from ipt include a 
C language debugger, a C compiler 
for DG systems, and a Unix operating 
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Another in a series of 
productivity notes on UNIX " 
software from UniPress. 


Subject: A complete Kit of compilers, 
cross compilers and assemblers. 

The Amsterdam Compiler Kit is the 
only C c nd Pascal UNIX package 
which includes a wide range of native 
and cro >s tools. The Kit is also easily 
modifiaple to support custom targets. 


COMPILERS 




Features: 

/ / / / / 

■ C and Pascal compilers (native 

and cross) for UNIX machines. 

■ Host and target machines include 
VAX '“ 4.114.2 BSD, PDP"*-11/V7, 
MC68000"* and 8086"* Cross 
assemblers provided for 8080™ Z80 ,™ 
Z8000 ,™ 8086': 6800: 6809: 

68000: 6502 and PDP-11. 

■ The Kit contains complete 
sources' 1 of all programs, plus com¬ 
prehensive internals documentation 
on how to make modifications needed 
to add a new program language or 
new target machine. 

*A source UNIX or C license is required 
from AT&T. 

/ //z//////,. 


Price: 


y/x/// f 

Full Source System $9950 

Educational Institutions 995 

Selected binaries are available - contact 
us with your machine type. 

For more information on these and 
other UNIX software products, call or 
write: UniPress Software, Inc., 2025 
Lincoln Hwy., Edison, NJ 08817. 
Telephone: (201) 985-8000. Order 
Desk: (800) 222-0550 (Outside NJ). 
Telex: 709418. Japanese Distributor: 
SofTec 0480 (85) 6565. European Dis¬ 
tributor: Modulator SA (031) 59 22 22 

/~y // / / % / / / 

OEM terms available. 

Mastercard/Visa accepted. 


AMSTERDAM 

COMPILER 

KIT 
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system for 16-bit DG systems. 

For more information, contact 
Information Processing Techniques 
Corp., 1096 East Meadow Circle, 
Palo Alto, CA 94304; 415/494-7500. 

Please circle Reader Service Number 170. 


AT&T SUPPORTS GSS 
STANDARDS 

GSS Graphics Standards have been 
selected for the new AT&T Unix pc. 
An integral part of the AT&T product 
offering is the GSS implementation of 
the Virtual Device Interface (vdi), 
being proposed by ansi as a com¬ 
puter graphics standard. The vdi 
allows an application program to con¬ 
trol any graphics device in a fully 
portable, device-independent man¬ 
ner. AT&T will supply the GSS VDI and 
peripheral device drivers on the 
AT&T Unix pc. 

AT&T has licensed and will offer 
the complete line of computer graph¬ 
ics products from GSS. AT&T also will 
offer, as optional packages, the C 
Language Bindings for the vdi (pro¬ 
vided with the AT&T Unix system 
Utilities Package), Gss-Chart, and 
GDI Sound Presentations. Later, the 
GSS-Toolkit family, which includes 
the Graphical Kernel System (gks), 
Plotting System, and Metafile In¬ 
terpreter, will be available on the 
AT&T Unix PC. 

For more information, contact 
Graphic Software Systems, 25117 
Southwest Parkway, Wilsonville, 
OR 97070; 503/682-1606. 

Please circle Reader Service Number 171. 


IBM SNA EMULATION 
SOFTWARE FROM 
SYSTEMS STRATEGIES 

Systems Strategies Inc., a devel¬ 
oper of IBM communications emula¬ 
tion software, has announced csna/ 
3270, an IBM Systems Network 


NEW PRODUCTS 


Architecture (SNA) emulation soft¬ 
ware package. 

csna/3270 allows a mini- or mi¬ 
crosystem with standard ascii CRTs 
and printers to emulate an IBM clus¬ 
ter controller operating in SNA/SDLC 
mode, with attached IBM 3278 CRTs 
and 3287 printers. It operates over 
dedicated or switched communica¬ 
tions lines. 

It allows manufacturers of 
general-purpose computer systems, 
pbxs, word processors, protocol 
converters, local-area networks, 
and intelligent workstations to con¬ 
nect non-IBM system mainframes 
through SNA networks. 

For more information, contact 
Systems Strategies Inc., 225 W. 
34th St., New York, NY 10011; 
212/279-8400. 

Please circle Reader Service Number 172. 


WHITESMITHS’ 

ENHANCED C COMPILER 
FOR 8086 FAMILY 

Whitesmiths Ltd. has announced an 
enhanced version of its C compiler 
product for the 8086-based family of 
computers. The compiler offers fea¬ 
tures that enable programmers to 
perform more functions with the 
single software development tool. 

Version 3.0, available in native 
and cross-compiler form, supports 
all members of the 8086 family, in¬ 
cluding 8088, 80186, 80286, 8087, 
80287, and math coprocessors. 

New features include the ability 
to support all 8086 memory models, 
as well as hybrid memory models 
that were previously available only 
to assembler programmers. These 
enhancements make Whitesmiths’ 
Pascal suitable for implementing a 
wider variety of applications. All 
compilers also now include the sys¬ 
tems’ interface library source code 
as a standard feature. 


Version 3.0 source code writ¬ 
ten for the 8086 now compiles under 
Whitesmiths’ C compilers for other 
systems, including the dec PDP-11 
and vax, Intel 8080, M68000, and, 
IBM 370. 

For more information, contact 
Whitesmiths Ltd., 97 Lowell Rd., 
Concord, MA 01742; 617/369- 
8499. 

Please circle Reader Service Number 177. 


TOOLS FOR C AND AI 
PROGRAMMERS FROM 
CCA UNIWORKS 

cca Uniworks has announced a spate 
of new products, including the Safe 
C Family of five C software develop¬ 
ment tools, the Runtime Analyzer 
for automatic detection of program¬ 
ming errors, the Interpreter for fast 
program turnaround, the Dynamic 
Profiler for high-resolution program 
monitoring, and the English-to-C 
Translator and C-to-English Trans¬ 
lator programming aids. 

ai programmers using vax sys¬ 
tems can now purchase common lisp 
and OPS5 for VAX from cca Uniworks 
and can combine them with CCA 
EMACS. Common lisp is a standard¬ 
ized and flexible version of lisp for 
use on vax systems under the Unix 
system, Ultrix, or VMS. ops5 is a 
new VAX programming language de¬ 
signed especially for developing 
expert systems. 

Also new is mprolog, a new 
modular version of the logic-based 
programming language, Prolog. 

Products distributed by cca 
Uniworks are supported under the 
Unix system (4.2BSD, System V), 
Ultrix, and vax/vms. 

For more information, contact 
cca Uniworks Inc., 20 William St., 
Wellesley, MA 02181; 617/235- 
2600. 

Please circle Reader Service Number 178. 


90 UNIX/WORLD 


JULY 1985 









TRENDS 


NEW PRODUCTS 


REPORT GENERATOR 
FOR PHACT ISAM 

UnPress Software Inc. has an- 
nouiced the Phact Report Gener¬ 
ator (Phact-rg), a report generator 
that provides a high-level command 
language for formatting reports in 
con; unction with Phact databases. 

Phact-rg complements Uni- 
Press’ existing Phact ISAM package, 
whi:h can access files either se¬ 
quentially or through keyed record 
access. Phact-rg is available on the 
IBM pc, VMS, and the Unix-based 
systems. 


Phact-rg supports multiline 
titles and column headings, dynamic 
fields and algebraic expressions, and 
can be run in interactive or batch 
mode. 

The instructions for Phact-rg 
are written in a simple report in¬ 
struction file that can be created 
with any editor or word processor. 

Phact-rg is priced at $165 for 
the IBM PC/MS-DOS, $275 for small 
68000s, $420 for large 68000s, and 
$575 for VAX machines running the 
Unix system or VMS. 

For more information, contact 
UniPress Software Inc., 2025 Lin¬ 


coln Highway, Edison, N.J. 08817; 
201/985-8000. 

Please circle Reader Service Number 179. 

OFFICE MANAGEMENT 
SYSTEM FROM 
MED-SYSTEMS 

Med-Systems has introduced a finan¬ 
cial and medical record management 
system for up to six physicians. The 
Professional Office Management 
System, Version 2, will perform 
the following functions: patient 
record retrieval, patient registra- 

Continued on pa^e 108 
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i }ct: Powerful Keyed File Access 
for liftIX-based systems. 


ISAM FILE SYSTEM 
& REPORT WRITER 


PHACT™ ISAM is a comprehensive 
manager which greatly eases 
;e and maintenance of keyed 
Record locking allows multiple 
taneous updates. 


ISAlVf 

the 

files 

simu 


u Si 


Features: 

m Keyed file access for UNIX, 

VMS ™ and MS-DOS ™ Designed for 
ease of use. 

■ A library of C functions, callable 
from any program. 

■ High-level utilities are included to 
build and maintain ISAM files. 

■ Up to 9 alternate indices are per¬ 
mitted for each file. 

■ Variable length records (1-9999 
bytes) are supported. 

■ Access on full or partial key. 

■ Record locking. 

■ Standalone PHACT available for 
use by non-programmers in building 
database applications. 

■ Optional, PHACT-rg, a powerful 
and flexible report generator which 
provides a high level, easy-to-use 
command language for formatting 
reports from existing PHACT data¬ 
bases. Available for UNIX, MS-DOS 
and VMS. 


Price: 

PHACT ISAM 

VAX™/UNIX 
MC68000™ /UNIX 
IBM-PC™ /MS-DOS 
VAX/VMS 
Source available. 
PHACT-rg 
VAX/UNIX & VMS 
MC68000/UNIX 
IBM PC/MS-DOS 
Source available. 


Binary 

$950 

450 

250 

2500 


$575 

275-420 

165 


PHACT 


For more information on these and 
other UNIX software products, call 
or write: UniPress Software, Inc., 
2025 Lincoln Hwy., Edison, NJ 
08817. Telephone: (201) 985-8000. 
Order Desk: (800) 222-0550 (Out¬ 
side NJ). Telex: 709418. Japanese 
Distributor: SofTec 0480 (85) 6565. 
European Distributor: Modulator SA 
(031)59 22 22. 

OEM terms available. 

Mastercard /Visa accepted. 


UNIX is a ademark ol AT&T BeH Laboiatones MS DOS is a trademark ot 
Microsoft mCT is a trademark ot PHACT Associates VAX/VMS arc 
trademark : ot Digital Equipment Corp MC68000 is a trademark ot Motorola 
Corp IBM PC is a trademark ol International Business Machines Corp 
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COMPLETE YOUR PROFESSIONAL LIBRARY ON THE UNIX SYSTEM! 




The Unix System Encyclopedia 
YATES VENTURES 

The UNIX System Encyclopedia is the larg¬ 
est available collection of information 
about the Unix marketplace. Over 400 
pages, with a comprehensive Unix direc¬ 
tory. Includes 100 pages of manufacturer 
specifications, photographs, software re¬ 
views, and articles on the Unix system. 
PUBLISHER'S LIST PRICE: $34.95 

The C Programming Language 
Kernighan/ Ritchie 
PRENTICE-HALL 

The C Programming Language is an in- 
depth guide to programming in C. A true 
classic, it appeals to all levels of expertise. 

PUBLISHER'S LIST PRICE: $22.50 


Understanding Unix- 
A Conceptual Guide 
Groff /Weinberg 
QUE PUBLICATIONS 


An excellent introduction for managers 
new to the Unix system, the Conceptual 
Guide introduces you to the reasons for 
implementing the Unix system. 

PUBLISHER'S LIST PRICE: $19.95 


A Practical Guide to the Unix System 

MarkSobell 

BENJAMIN CUMMINGS GROUP 

A Practical Guide to the Unix System is an 
excellent reference as well as a detailed 
learning tool. As an added bonus, the au¬ 
thor had included a comprehensive over¬ 
view of Xenix. 

PUBLISHER'S LIST PRICE: $22.95 


A user Guide to the Unix System 
Second Edition 

Dr. Rebecca Thomas/Jean Yates 

OSBORNE MCGRAW-HILL 

Takes up where A User Guide to the 
Unix System left off. The basics of the Unix 
System for novices, with hands-on tu¬ 
torials. 

PUBLISHER'S LIST PRICE: $18.95 


ITEM 


QTY PRICE TOTAL 


User Guide to the Unix Syst. Second. Ed. 
Thomas/Yates U 200 




Practical Guide to the Unix System 

Sobell U201 




The C Programming Language 
Kernlghan/Rltchie U202 




Understanding Unix, Conceptual Guide 
Groff/welnberg U203 




The Unix System Encyclopedia, 

Yates ventures U204 




SUBTOTAL 

SAVE! IF YOUR ORDER IS FOR MORE 
THAN ONE BOOK, SUBTRACT 20% HERE 

CA RESIDENTS ADD 6.5% SALES TAX 

SHIPPING AND HANDLING 

GRAND TOTAL 












$2.50 





SAVE ON ORDERS OF TWO BOOKS OR MORE, TAKE 
20 % OFF THE SUGGESTED LIST PRICE! 


Ship Order to: 
Name:_ 


Company. 


Add. 

City. 


.State . 


Signature. 


□ Check Enclosed 

□ Please Charge to My: 

□ Mastercard_ 

□ Visa Card_ 


ADDRESS ORDERS TO: 


UNIX/WORLD Magazine 
Tech valley Publishing 
444 Castro St., suite 1220 
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SERIES PART 3, 
A FILE SYSTEM 
CHECKUP 


BY DR. REBECCA THOMAS 


I f you’ve been with us these last 
two months, then you know that 
starting up your Unix system 
Mm requires a lot more than merely 
the flick of a switch. For one thing, it 
requires a healthy file system. 

In the last installment we men¬ 
tioned the importance of checking 
and repairing the file system when¬ 
ever you start up. In this installment 
we detail how to do this file check 
and repair procedure using the com¬ 
monly occurring f 5 c k program. 

Before discussing checking and 
repairing the file system, however, 
we need first to present a brief over¬ 
view of the file system parts with 
which you need to be familiar. In the 
next section we describe the three 
major parts to every file in the Unix 
file system. 

First is the inode. Each file is 
described by a structure called an 
inode. Inodes are located in special 
data blocks (not used for file data), 
and each 512-byte block can contain 
as many as eight 64-byte inodes. 
The inode contains all the data about 
the file except the file name and the 
actual data contained in the file. Note 
that the disk addresses (locations on 
disk) for the file’s data blocks are 
contained in the inode area. The 
inodes are numbered from 2 (re¬ 
served for the root directory, “/”) 
through 65,535. This unique identi¬ 
fying number is known as the inode 
number or simply the i-number. 

Then, there are the data blocks, 
which are located on another area of 
the disk and contain the actual data in 
a file. Each block can typically hold 
512 characters. Some Unix system 
implementations (such as the Berke¬ 
ley Unix system) use larger block 
sizes ranging from 1024 characters 
and up. Even if the file contains only 
one character, an entire data block 
must be allocated to hold this single 
character. 
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MANY UNIX-BASED SYSTEMS 
ONE UNIX TRAINING COMPANY 


The Computer Technology Group provides the UNIX training solution. 
Training to fit the complexities of your UNIX-based system. 

Three factors make the Computer Technology Group the experts in UNIX and ‘C 
language training: 

• Experience, through training thousands of students worldwide in live seminars, 
with thousands more using our video training at their own locations. 

• Extensive Curricula Supporting All UNIX Versions, creating a client base of 
manufacturers, software developers and end users. 

• Quality of Instruction, with instructors and course developers who are experts 
in teaching UNIX and ‘C, as well as in designing and implementing a variety of 
UNIX-based systems. 

ONE UNIX TRAINING COMPANY 
MULTIPLE DELIVERY SYSTEMS 

Whether you’re training two, 200,2000.. .you can select the most efficient and 
economical training solution for your unique environment: 

• Public Seminars offered in major cities throughout the world. 

• On-Site Seminars for training customzied to your system and to specific 
groups within your organization. 

• Video-Based Training for consistent training that is always available at your 
location. 

• Interactive Videodisc Training, which dynamically tailors courses to the indi¬ 
vidual—from novice to expert programmer. 

Please circle Ad No. 115 on inquiry card 


ASK FOR OUR 48-PAGE COURSE 
CATALOG, WHICH PROVIDES: 

• Comprehensive course outlines 

• Course prerequisites 

• Curriculum recommendation for 
multiple audiences 

• Guidelines for cost-effective train¬ 
ing media selection 

• Current seminar schedule 

CALL (800) 323-UNIX or 

(312)987-4082 in Illinois 

™ UNIX is a trademark of Bell Laboratories. 
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FIGURE 1: THE RELATIONSHIP BETWEEN DATA BLOCKS, THE INODE, 
ANL A DIRECTORY ENTRY 


The last part of a Unix file is the 
direc tory , which lists one or more file 
names. Each entry in a directory 
cont fins one file name and the inode 
num 3er that points to the inode for 
the corresponding file. Note that di¬ 
rectories themselves also have an 
inode structure. 


SHO 

REL 


WING THE 
ATIONSHIP 


Figure 1 shows the relationship be¬ 
tween the data blocks, the inode, 
and a directory that references an 
ordinary file. In this figure we show 
that the directory associates the file 
name poem with the inode for the 
file (we show 23284 as the inode 
number). We also show the inode 
pointing to a data block. The data 
block contains the actual characters 
in th * file. 

Besides these file system 
strut tures, we need to mention two 
other components important for ad- 
minis tration of the file system. 

The superblock is a very special 


block in the file system. It contains 
global information about the file sys¬ 
tem such as the file system name, 
the total size of the file system, the 
total number of free data blocks and 
free inodes, and so on. 

A copy of the superblock is kept 
in memory at all times for easy ac¬ 
cess by the Unix system kernel. To 
update the disk copy of the super¬ 
block, you must perform a sync 
operation. Most Unix system imple¬ 
mentations run an update daemon 
process in the background, which 
executes sync periodically to up¬ 
date the disk copy of the superblock. 

The free-block list, the final 
component of the file system you 
need to know about, is a chain of 
blocks that contain the disk address 
of all the data blocks in the system 
that are available for use by a file. 
Part of this list is maintained in the 
superblock structure. 

Now let’s learn about operating 
the fsck command, which can 
check the integrity of the file system 
and can direct any needed repairs 
interactively. 


OPERATING THE fsck 
PROGRAM 


The file system check utility is an 
interactive program that will prompt 
you for yes or no decisions on 
whether to correct certain error 
conditions. It is a good idea to run 
fsck one time through, answering 
no to all queries, in order to assess 
the scope of any problems before 
you direct fsck to repair any error 
conditions. Figure 2A shows one 
possible command line format for in¬ 
voking fsck. 

Here filesystem is the name of 
the file system to be checked. In 
general, you don’t have to supply 
this argument because fsck will 
obtain the names of the file systems 
to be checked from the ordinary file 
/etc/checklist (Bell) or /etc/ 
fstab (Berkeley). 

The fsck program will auto¬ 
matically answer no to all queries if 
you invoke it with the -n option. 
One reason for this conservative ap¬ 
proach would be that the problem 
lies with the hardware and not with 
the data on the system disk. In this 
case, you wouldn’t want fsck to at¬ 
tempt repair of the file system data 
structures. 

Immediately after invocation, 
fsck enters an initialization phase. 
If fsck cannot get enough memory 
to store its intermediate results, it 
may query you to name a file to 
be used temporarily as a “scratch 
pad” during the checking procedure. 
There need be nothing special about 
the particular name you choose, but 
if possible you should select a path 
name so that the scratch file is not on 
the file system being checked. 

Figure 2B shows an example of 
output from fsck if there are no 
errors. The program may first print 
the name of the file system it is 
about to check, and then it scans that 
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a. A Sample Command Line Format: 
/etc/fsck I -y ] [ -n ] [filesystem ] 

b. Sample Output: 

# /etc/fsck 
/dev/root 

** Phase 1 — Check Blocks and Sizes 
** Phase 2 — Check Path Names 
** Phase 3 — Check Connectivity 
** Phase 4 — Check Reference Counts 
** Phase 5 — Check Free List 
414 files 9857 blocks 7560 free 

# □ 


FIGURE 2: OPERATING THE fsck PROGRAM 


# /etc/ncheck -i inodenumber ... filesystem 

# □ 


FIGURE 3: USING ncheck TO DETERMINE FILE NAME 


file system several times, as shown 
by the different “phases/’ Finally, 
some statistics about the file system 
are displayed. 

Now we’ll discuss operation of 
the f 5 c k program in more detail, 
examining each phase of fsck’s 
operation and some commonly oc¬ 
curring informational and error mes¬ 
sages and how to deal with them. 
You need to study this material clo¬ 
sely because the correct operation 
of the fsck program is critical to 
repairing and maintaining a file sys¬ 
tem. Before we discuss the phases 
of fsck, you need to know how to 
clear a corrupted inode. 

ZAPPING INODES 

Many of the f s c k queries ask you to 
“CLEAR?” an inode because it is 
corrupted. If you answer yes, the 


inode is cleared by writing all zeros 
into it, and the corresponding file is 
destroyed. Sometimes you can save 
the data in the file by first copying 
the file contents to another location 
in the file system. 

In saving a file, first answer no 
when the f s c k program displays the 
“CLEAR?” query on a bad inode. 
The fsck program will also display 
the inode number (indicated after 
“I = ”) and the size of the file (indi¬ 
cated after “SIZE = ”). You should 
record these figures because you 
will need them later. Continue with 
the fsck program, answering no to 
any “CLEAR?” prompt on an inode 
you intend to save. 

One deficiency of the file check 
program is that you cannot deter¬ 
mine the name of the file from the 
bad inode because fsck simply re¬ 
ports the inode number. This is a 


situation where the ncheck pro¬ 
gram comes into play. After re¬ 
turning to the shell, use the n c h e c k 
program to determine the file name 
associated with the bad inode. Fig¬ 
ure 3 shows the command line syn¬ 
tax for using ncheck to determine 
the file name. Here inodenumber is 
the inode number of the file you are 
searching for, and filesystem is the 
name of the file system you are 
checking. 

If no file name was reported by 
nchec k, the file is unreferenced (by 
a directory entry), so you can’t ac¬ 
cess it for a backup with a Unix sys¬ 
tem utility. If the file is referenced, 
however, a file name is displayed. 
You can use a utility such as cat to 
examine the contents of the file. If 
the data is intact, you should back 
up the file contents, say with c p or 
tar, to a different file system. 

After saving the contents of any 
bad file, rerun the fsck program, 
but this time answer yes to the 
“CLEAR?” queries. After the file 
system is clean (no errors reported 
during a f sc k run), retrieve the file 
that was saved earlier. 


THE fsck PROGRAM 
GOES THROUGH PHASES 

Now we will discuss the remaining 
operational phases of the fsck 
program. In the phase numbered 
1 , each inode in the file system is 
checked for its own data integrity, 
and then the disk blocks pointed 
to by the inode are checked. Sev¬ 
eral error messages at this stage 
are possible. “UNKNOWN FILE 
TYPE” means the inode is corrupted 
and should be cleared after the file 
contents are backed up. 

If the message “BAD” occurs, 
the block address in the inode is 
invalid. Another common error mes- 
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sag4 is “DUP” (for duplicate), which 
occurs if a block has already been 
led by another inode. You will 
be prompted to remove “BAD” 
DUP” blocks until phase 2 or 4. 
large number of “DUP” and 
D” blocks result from a dam- 
indirect block , which is a data 
containing addresses of other 
blocks for the file. 

Another warning message is 
“POSSIBLE FILE SIZE ERROR,” 
which occurs if the estimated num¬ 
ber of blocks for an ordinary file does 
not agree with the actual number 
of blocks claimed by the inode. 
The “DIRECTORY MISALIGNED” 
mes sage occurs if the size of a direc¬ 
tory file is not a multiple of 16 bytes. 

If these last two error condi¬ 
tion^ aren’t cleared during the inter¬ 
active repair in later phases of this 
program, you should back up the 
file or directory contents. Manually 
erase the file (with rm) or directory 
(with rmdir), and the corrupted 
inoce will be de-allocated. After 
that, run f sc k again to be sure the 
file system is now clean. 


If any “DUP” blocks were dis¬ 
covered in phase 1, this error will 
initiate another scan of the inodes, 
as indicated by the message “Phase 
lb—Rescan for More DUPS.” 

If a block that has been claimed 
by the inode being examined has al¬ 
ready been tagged as a “DUP,” the 
“DUP” warning message is re¬ 
peated, and you will be prompted 
“CLEAR?” If you answer yes, the 
inode will be marked for possible re¬ 
moval in a later phase. 

ANOTHER ERROR 
MESSAGE 

Another possible error message 
during phase 1 is “PARTIALLY 
ALLOCATED INODE. ” This means 
that the inode is neither allocated 
nor unallocated. You should answer 
yes to the following “CLEAR?” 
prompt, but you may want to back 
up the associated file before clearing 
the inode. 

In phase 2, fsck inspects all 
directory inodes in the file system. 
First the inode for the root direc¬ 



[JLOSSARY/COMMAND summary 


cat 

Display the contents of one or more files 


CD 

Copy the contents of a file 


fsck 

Check consistency of file system and 
repair interactively 


fsdb 

File system debugger; can be used to 
patch a damaged file system 


mklost+found 

Shell procedure used to create the 
lost+found directory 


mv 

Move (by renaming) a file 


rm 

Remove an ordinary file by removing a 
directory entry (or link) to the file 


rmdir 

Remove a directory file 


nchec k 

Generate a path name from an inode 
number 


sync 

Update the disk copy of the superblock 


tar 

Tape file archives; may be used to copy 
one or more files (or directory 
contents) to another part of the on-line 
file system or backup media 
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tory is examined. If fsck reports 
it “UNALLOCATED,” fsck will 
abort because this means the root 
inode is corrupted. If you get the 
message “DUPS/BAD IN ROOT 
INODE (CONTINUE)?” answer 
yes, but expect a large number of 
related file system errors as a result 
of this last error condition. 

fsck can fix most file system 
errors, except for a corrupted su¬ 
perblock or inode. In some cases, 
even these structures may be re¬ 
paired by someone experienced with 
the file system and the file system 
debugger program, fsdb. 

Continuing with phase 2, the 
inode (and each block for that inode) 
corresponding to each directory en¬ 
try in the file system is examined. 
One error condition that could occur 
here is “OUT OF RANGE,” which 
means that the inode number of the 
directory entry is invalid. If you elect 
to remove the inode in response to 
the “REMOVE” prompt, the inode 
field of the directory entry will show 
zero. 

An “UNALLOCATED” mes¬ 
sage means the inode is possibly un¬ 
allocated, but it should be allocated 
because it is referenced by a direc¬ 
tory entry. In this case, answer yes 
to the “REMOVE?” prompt so that 
the directory entry doesn’t point to 
an unallocated inode. 

At this point you will be given 
the opportunity to clear the inodes 
that had a “BAD” or “DUP” block 
discovered during phase 1 or lb of 
the check procedure. The fsck pro¬ 
gram may supply you with a file 
name, or you can use ncheck to 
determine it from the inode number. 
If the file is of no value to you, an¬ 
swer yes to clear the inode. The 
“DUP” blocks are frequently shared 
between a file and the free-block list, 
so in this case don’t clear the inode. 
Instead, wait for an additional phase 
6 , which rebuilds the free-block list. 
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# cat mklost + found 

echo ‘Mount point (pathname) for file system? (RETURN) for /’ 
read rootdir 

cd ${rootdir}/lost + found 

for file inl234567890abcdef 

do 

>$file 

done 
rm * 

# □ 


FIGURE 4: A TYPICAL mklost+found SHELL PROCEDURE 


PHASES 3 AND 4 

In phase 3 all the allocated inodes 
are scanned for unreferenced direc¬ 
tories; that is, directories where the 
inode corresponding to the parent 
directory entry (. .) does not exist. 
In this case you will be prompted to 
“RECONNECT?” any orphaned di¬ 
rectories. If you answer yes, a link 
from the orphan directory to the 
special directory lost+found will 
be made. The name of the link to the 
lost ■♦■found directory will be the 
inode number from the orphan, now 
newly connected, directory. After 
the f s c k program is finished, you 
can examine the entries in lost + 
found and move them (by renaming 
with mv) to their appropriate place in 
the file system. 

If a lost+found directory 
doesn’t exist in your file system, you 
can easily create it if your system 
has the mklost+found shell 
script. This command creates the 
lost+found directory by making a 
large number of directory entries 
and then deletes them to give a 
large, but empty, directory. If you 
delete an entry (file or directory) 
within a directory, the size of the 
directory isn’t changed. 

If you don’t have the m k 1 o s t + 
found shell script, you could simu¬ 
late the procedure by changing to 


the root directory of the file system 
and entering mkdir lost + found 
and then cd lost + found. Next, 
create several dummy files and then 
remove them (with rm). Figure 4 
shows a typical mklost+found 
(Bourne) shell procedure to accom¬ 
plish this task. 

Phase 4 is concerned with the 
link count or reference count infor¬ 
mation that was accumulated in 
phases 2 and 3. In phase 1 the refer¬ 
ence count is first set to the link 
count value stored in the inode. The 
link count is the number of links (or 
file name aliases) for that physical 
file. Then, in phases 2 and 3, the 
reference count is decreased each 
time a valid link is found while scan¬ 
ning the file system. So the refer¬ 
ence count value should be zero 
when phase 4 begins. 

If the reference count for an 
inode was actually zero to begin with 
in phase 1 (indicating a corrupted 
inode), you may clear the inode at 
this point. To do so, answer yes to 
the “CLEAR?” query for the un¬ 
referenced file “UNREF FILE” or 
directory “UNREF DIR.” 

If the reference count for the 
inode is not zero at the start of phase 
4, not all the links were discovered 
in phases 2 and 3. The f 5 c k pro¬ 
gram distinguishes between two 
cases at this point: (1) none of the 


claimed links were discovered, in 
which case the inode refers to an 
“orphan” file or directory; and (2) 
not all of the claimed links were dis¬ 
covered, in which case the fsck 
program can correct the link count 
field in the inode. 

In the first case, f 5 c k can link 
the orphaned file or directory to the 
lost + found directory. You should 
answer yes to the “RECONNECT?” 
query to accomplish this. If this link¬ 
age operation was not successful, 
or if you decided not to link, then 
answer yes to the subsequent 
“CLEAR?” query associated with 
the next “UNREF FILE” (or “DIR”) 
message. 

In the second case, fsck will 
adjust the link count if you an¬ 
swer yes to the “ADJUST?” query 
that follows the “LINK COUNT 
FILE” (or “DIR”) and “COUNT X 
SHOULD BE Y” message. 

In the last stage of phase 4, you 
are given the chance to clear the 
inodes of unreferenced files and files 
containing bad or duplicate blocks. 
Finally, if you get the error message 
“FREE INODE COUNT WRONG 
IN SUPERBLK,” you should an¬ 
swer yes to the “FIX?” query. 


PHASE 5 

Phase 5 checks the free-block list. 
Any bad or duplicate blocks in this 
list are flagged, and later you will get 
the message “BAD FREE LIST” 
and be prompted to “SALVAGE?” 
(to which you should answer yes). 
After you have elected to salvage 
the free list, a phase 6 is initiated, 
which reconstructs the free block 
list. 

If a file system was corrupted 
and then fixed, you will get a mes¬ 
sage like “****** BOOT UNIX 

QVNf'M ******” nr <<****** 

FILE SYSTEM WAS MODIFIED 
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just before fsck exits, 
message means that fsck had 
odify the file system in order to 
it. To prevent the work done 
sek from being “undone,” the 
m should be rebooted without 
irming a sync operation (see 
month's installment for more 
sync). 

At this point, shut the system 
by simply turning off the 
wait several seconds, and 
turn on the power (or press 
Reset” switch, if available) and 
;trap the system again. This is 
mly time you should ever shut 
or reset the system without 
>rming a s y n c command first. If 
were errors on the last run, 
should repeat the fsck program 
no more errors are reported. 

If you follow the steps outlined 
is installment for checking and 
>airing your file system, you will 
keep your Unix system alive 
well. 

Next month our “Cures For 
jess Ills” turns to a discussion 
le general steps you would use 
'eate a new file system. Then, 
use your Unix system can’t be 
when the system disk fills up, 
discuss several utilities and ap¬ 
aches for managing this valuable 
;curce. □ 


Dr. Rebecca Thomas, Unix /World's 
Editor Emeritus, is an author of A User 
Guide to the Unix System, the second edi¬ 
tion of which is now available. She is cur¬ 
rently writing a book on Unix system 
administration. 


This article is based on A User 
GuicU to the Unix System, second edi¬ 
tion, by Dr. Rebecca Thomas and Jean 
Yates. Copyright (C) 1985 by McGraw- 
Hill Inc. Used with permission of 
Osborne /McGraw-H ill. 
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At long last, ITDC—a leading supplier of UNIX 1 " and C software con¬ 
sulting, development and education services—is making its highly 
successful education courses available to the public. Taught in a class¬ 
room environment that offers over 50% hands-on training, our courses 
are taught by professionals for professionals. 


1985 Summer, Fall and Winter Course Schedule 


UNIX for Application Developers June 17-28, September 9-20, November 11-22 
UNIX for End Users July 15-19, August 5-9, October 14-18, December 2-6 


C Programming Language July 22-August 2, September 30-October 11 


C-Shell Programming August 26-30, November 4-8 

BOURNE Shell Programming August 19-23, October 28-November 1 

UNIX Systems Administration September 23-27 

INFORMIX* Relational Data Base July 8-12, August 12-16, October 21-25 

ITDC’s courses are taught in Cincinnati, Ohio. Enrollment in any of the 
classes listed in the course schedule may be accomplished by con¬ 
tacting ITDC by phone or letter. 

ITDC requests that you register well in advance of the course date, as 
ITDC classes are well attended and enrollment is limited. If a purchase 
order or payment has not been received at least two weeks before the 
class starts, your reservation will not be guaranteed. 

Tuition is $500 per student for one week courses and $1000 per stu¬ 
dent for two week courses. Payment may be made by confirmed com¬ 
pany purchase order, check or money order. 

UNIX is a trademark of AT&T Bell Laboratories. INFORMIX is a trademark of Relational 
Database Systems. 


Please circle Ad No. 49 on inquiry card. 
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THE MORE YOU KNOWABOUT UNIX; 
THE TALLERTHE TOWER XP STANDS. 


The engineers at NCR are now 
convinced that UNIX is the best operating 
system in the industry. 

Of course, to convince these reliability 
fanatics, UNIX had to endure thousands 
of hours of grueling tests. But that’s simply 
the price any component must pay to 
get into an NCR product. 

And it’s a better UNIX 
for the experience. 

The NCR-enhanced 
UNIX in the Tower XP is 
the first UNIX of true, 
commercial reliability. 

It virtually never 
PANICS. Consequently, 
neither do your customers. 

So that this UNIX 
might be all things to all 
users, we employed the 
Tower XP’s menu builder to 
create the five faces of 
UNIX. A remarkable case of 
multiple menu personalities. 
One for each of five user 
levels, from sophisticated 
user to data duffer. 

And our UNIX speaks 
a language for each of five programmer 
types: Business BASIC, Pascal, Fortran, 

C, and Cobol. 

Team this powerful operating system 
with the Tower XP’s other prodigious 
features; consistent error logging, exten¬ 
sive remote and in-service diagnostics, 
Automatic Power Failure Recovery, and 
more, and you’ve got a monumental 
mixture. Capped by NCR’s towering 
commitment to OEMs. 

The more you know about Tower XR 
the better NCR looks. 



TOWER XP 

BUILT FOR SYSTEMS BUILDERS 
BY NIT-PICKING FANATICS. 




OEM Systems Division 


NCR Ccrporation, U.S. Data Processing Group. OEM Systems Division. USG-1, Dayton. Ohio 45479. Nationwide (800) CALL NCR. In Ohio (513) 445-2190. In Canada (800) 268-3966. 

•unix i > a registered trademark of at&t. Please circle Ad No. 26 on inquiry card. 
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able interface that should satisfy 
both user groups. 

If the facility does favor one 
group of users over the other, it is 
probably biased toward helping be¬ 
ginners. This is appropriate because 
beginning system users are the ones 
who presumably most need an on¬ 
line help facility. Even so, several 
features have been added that allow 
more experienced users to retrieve 
the information contained in the sys¬ 
tem more quickly; these features 
should become evident as the user 
interface is described. 

Basically, the help facility is a 
menu-driven system. The simplest 
way to enter the facility is to type 
“help” at shell command level. This 
yields a menu that allows the user 
to select either the starter, 
glossary, usage, or locate 
modules of the facility. Each of these 
four modules can also be entered 
directly from shell command level. 
For example, the usage module can 
be entered by typing either “usage” 
or “help usage” at shell command 
level. 

Once inside the s t a r t e r , 
glossary, usage, or locate 
module, users can obtain specific 
information. In starter, the infor¬ 
mation is accessed by making a se¬ 
lection from a menu. In glossary, 
entering the name of a term or sym¬ 
bol retrieves its definition. In usage 
and locate, the system requests 
either a specific command name or a 
set of keywords, respectively. 

After processing the input, 
either the requested starter in¬ 
formation, the definition, the com¬ 
mand information, or a list of appro¬ 
priate Unix system commands, 
respectively, is output to the user’s 
terminal. 

The glossary, usage, and 
locate modules can be entered 
directly from shell command level by 


typing (for glossary) “glossary 
term” or “help glossary term” 
(where “term” is a Unix-related term 
or symbol), (for usage) “usage 
[-d/-e/-o] command_name” or “help 
usage [-d/-e/-o] command_name,” 
or (for locate) “locate keywordl 
[keyword2]” or “help locate key¬ 
wordl [keyword2]”. 

In the usage module, the op¬ 
tion “-d” retrieves the syntax sum¬ 
mary and description of the specified 
command and is the default. The op¬ 
tion “-e” retrieves the examples, 
and the option “-o” retrieves the op¬ 
tion descriptions. 

Every screen, whether it is pri¬ 
marily a menu screen or not, con¬ 
tains a list of options available to the 
user at that point. Obviously these 
options vary from screen to screen, 
and there is not enough space here 
to describe every screen in the sys¬ 
tem. Nevertheless, we can describe 
the options in general terms and pro¬ 
vide a reasonably thorough under¬ 
standing of how the facility works. 
At every point, the user has the fol¬ 
lowing set of options: 

• The user can proceed with entry 
to a module of the facility, or with 
some processing within a module. 

• The user can always restart the 
current module. 

• The user can always “advance” to 
the next screen. 

• The user can always exit directly 
to the Unix shell. 

• The user can always return 
directly to the initial help menu, 
if that is where the facility was 
entered. 

• The user can always escape to 
the Unix shell to execute a command 
and then return to his or her current 
location in the facility. 

Aside from the rules given in 
the last paragraph, the only general 
principle we used in designing the 
facility was to make sure that the 


information it contains is densely 
packed. Quite justifiably, most users 
strongly object to retrieving screen 
after screen of menus and inter¬ 
mediate information before reaching 
the information they need. 

Certain advantages do accrue 
for beginners if they are given only a 
small amount of information in each 
display, but we believe these ad¬ 
vantages to be far outweighed by 
the irritation this sort of procedure 
causes in experienced users and by 
the disorientation that nearly every¬ 
one experiences after traversing a 
long series of screens. Conceptually, 
the help facility described here is 
never more than three layers (or 
screens) “deep.” This results in a 
quite dense packing of information. 

In summary, the he 1 p facility is 
an interactive utility available at shell 
command level that provides a vari¬ 
ety of information on the Unix sys¬ 
tem. Although the facility is menu 
driven, it allows direct access at two 
interior levels from the shell so that 
experienced users can retrieve in¬ 
formation quickly. In addition, the 
facility’s data can be expanded and 
customized using a set of software 
tools provided with the facility. 

We spent much time design¬ 
ing the flow of control through 
the facility, and we believe we 
have achieved our goal: a terse, but 
easy-to-use structure and command 
language. □ 


Mr. Butler holds a doctorate in psychology 
from Brown University. He joined AT&T 
Bell Labs in 1978 and currently works in 
a group developing new features for the 
Unix System kernel. Ms. Kennedy is cur¬ 
rently completing an M.S. in computer 
science at Rutgers University. She joined 
AT&T Bell Labs in 1979 and currently is 
a Unix System utilities systems engineer. 
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WIZARD’S G R ABBAG 


A POSTMAN AND 
A PHILOSOPHER 


BY DR. REBECCA THOMAS 



In this month’s 
installment of 
“Wizard’s Grab- 
bag,” we have 
several reader 
contributions to 
share with you, 
including a shell 
script for for¬ 
matting mailing labels and some 
thoughts on Unix system philosophy. 


Dear Dr. Thomas: 


Hen 

mat|t: 

mai 

1A 

mk 

with 

and 

with 


e’s a shell script useful for for¬ 
cing records of a mailing list into 
li ing labels. [Doctors note: Figure 
lists this Bourne shell script, 
abel.] You may use this script 
the C shell if it begins with a 
if every “Newline” is escaped 
a backslash. 


The input data file for the 
mk label program must consist of 
name and address fields (and possi¬ 
bly other data) separated by a partic¬ 
ular field-separation character (one 
not used within the field itself). For 
this example, each record in the data 
file consists of six fields—name, 
company name, street address, city, 
state, and zip code—separated by 
commas. All records should contain 
this same number of fields. Also 
there should be no extra “Newlines” 
at the end of the data file. 

[Doctors note: Figure IB lists a 
sample data file, and Figure 1C 
shows the shell script being used in 
a typical application. Here the shell 
is directed to pipe the output of 
grep, which selects only people in 
California, into sort -n, which then 
orders the selected records by zip 
code, and then into m k 1 a b e 1, which 
in turn formats the data into labels— 
one across, six lines per label, in¬ 
cluding one line between each. 
Finally, the result is sent to lpr for 
spooling on the system line printer. 


You can view a copy of that same 
data stream on your terminal be¬ 
cause we inserted tee /dev/ tty 
into the pipeline. ] 

Ray Swartz 

Berkeley Decision/Systems Inc. 
Santa Cruz, Calif. 

SOME UNIX PHILOSOPHY 
AND OTHER THOUGHTS 

Dear Dr. Thomas: 

I’m submitting some thoughts from a 
Unix manager’s guide that I devel¬ 
oped in high school, when I had to 
teach younger students how to man¬ 
age our Unix Version 7 on a PDP 
11/34: 

Unix systems tend to encour¬ 
age the programmers that use them 
to improve their system and person¬ 
alize it. This is what keeps Unix alive 
and well. I do not claim that Unix 
is, as it stands, a complete system. 
This is probably why everyone 
ends up personalizing and modifying 


a 

. The m k 1 a b e 1 Bourne Shell Script 


$ 

cat mklabel 


c 

wk 7 BEGIN {FS = M , "> 



{ for (count = 1*, count <= 3; count = count + 1 
print Scount 

printf ,,0 /o5, Is %5\n\n\n'\ $4, $5, $6 

□ 

) 

$ 


b 

. The sample input data file 


$ 

cat database 


F 

ay Swartz,BD/S Inc.,150 Belvedere Ter race,Santa Cruz 

, CA. ,95062 

F 

red Unix, AT&T Technologies Inc.,P.O. Box 25000,Gree 

nsboro,NC. ,27420 

F 

lebecca Thomas,UN IX/Wor1d Magazine,444 Castro St.Suite 

i □ 

1 220, Mountain View,CA.,94041 
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c. A typical application for using m k 1 a b e 1 

$ grep CA database ! sort -t, +5 ! mklabel ! tee /dev/tty ! lpr 

Rebecca Thomas 

UNIX/World Magazine 

444 Castro St. Suite 1220 

Mountain View, CA. 94041 

Ray Swartz 
BD/S Inc. 

150 Belvedere Terrace 
Santa Cruz, CA. 95062 

$ □ 


FIGURE 1: THE mk label BOURNE SHELL SCRIPT AND ITS USAGE 


it. In my four years as a Unix sys¬ 
tem programmer/manager /wizard, 
I have come to the following con¬ 
clusions: 

(1) The installation of a Unix 
system is never complete. 

(2) The Unix system is dynamic 
and must stay that way if it is to keep 
up with the rest of the software 
world. 

(3) Copyrighting/protecting 
software/ideas only hinders the 
progress of Unix development in 
general. 

(4) The concept of “software 
toolboxes” should be introduced to 
the entire Unix community. These 
toolboxes should be relatively free 
of copyright shoestrings and other 
such development hindrances. By 
“toolbox,” I refer to a complete set 
of routines which performs a specific 
sub-task within a given system. 

For example, all programmers 
(if they are worth their salt) have 
written, possibly on multiple occa¬ 
sions, list processors of some sort. 
A package that does all sorts of list 
processing, such as the one that I 
have, saves gobs of time and money. 
It is public domain, and the only re¬ 
striction is that if you pass it on to 


someone else there will be no 
money changing hands on the deal. 
Neat, huh? and very helpful. (I must 
give credit for this idea to Bob Zim¬ 
merman, a Camegie-Mellon Univer¬ 
sity programmer/wizard.) 

(5) Many people think of the 
operating system as sacred terri¬ 
tory. This is a gross misconception. 
Unix must advance on all levels, in¬ 
cluding the operating system, librar¬ 
ies, “bin” programs, etc. Those 
without source licenses of some sort 
have a definite problem with modi¬ 
fying the operating system and “bin” 
programs. But adding libraries and 
even replacing “bin” programs with 
better ones is still possible, and 
many debuggers make it possible to 
modify the code in its compiled form 
anyway. You need not be a systems 
person to make changes as long as 
you understand what you are doing 
before you do it. Caution is a pro¬ 
grammers best friend. 

Regarding the “Grabbag” con¬ 
tribution in Vol. 1, No. 5: 

Adding a shell script front-end 
for message transmission seems to 
me to be overdoing it a little.... 
The mail program can easily be 
modified to report the fact that mail 


has arrived for a user if he is logged 
in. [Doctor's note: Some systems are 
already set up to do this. For these, 
simply initialize the MAIL environ¬ 
ment variable to the path name for 
the recipients mail file.] The user 
then reads the message (memo) 
when he or she feels like it. 

This requires a small and 
straightforward modification to the 
mail subroutine that actually writes 
the message to the users mail file. 
When any message is written, this 
routine should also (1) check if the 
user is logged on, and if so (2) get 
the name of the terminal being used, 
and then (3) send to that terminal a 
couple of “Newlines,” whom the 
message is from (sender/user id), 
the subject of the message, and per¬ 
haps a couple of “Bell” characters 
(“Control-G”). 

If you don’t have the source 
code for the mail program, here is 
an alternate suggestion with slightly 
more overhead: 

Rename the original mail pro¬ 
gram to, say, do-mail. Write a 
“driver” program, naming it mail. 
The driver looks at its invocation 
arguments, and if you are sending a 
message to another user, the driver 
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ilds the message (without the sub¬ 
field) to the recipient’s terminal 
logged in). 

The driver then “fires up” do- 
i 1 with the same invocation argu- 
nts. This approach has one obvi- 
flaw—if you send someone a 
ie|ssage and then abort, the recip- 
will still get the message (on the 
een, at least). 

Obviously, these alternate solu- 
tiois are not complete because you 
would rather have our messages de¬ 
livered immediately. 


sei 

jec|t 

(if 

ma 

me|] 

ou$ 

m< 

ienjt 

SCI < 


can’t specify a time for message 
delivery, but some of us (1) don’t 
have the at program on our sys¬ 
tems, (2) use calendar for our 
personal reminder service, or (3) 
One copy of it needs to sit 
somewhere, with all the programs 
that you wish to account for linked 
to it. Any call for those programs 
(that is, the driver) would do several 
things. First, it would record the 
program name and arguments, date, 
Have you ever wished to find 
out quickly, without going through 
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B+ Tree based file handlers. With c-tree™ 
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• complete C source code written 
to K&R standards of portability 

• high level, multi-key ISAM routines 
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• no royalties on application programs 
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Specify format: 

5'/V' PC-DOS W Mac 
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1-314-445-6833 
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c-tree and the circular disc logo are trademarks 
of FairCom UNIX is a trademark of Bell Laboratories 
Apple is a trademark of Apple Computer, Inc. 
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the system accounting files, how 
many times anyone uses a program 
that exists on the system? How 
about accounting for the usage of 
any /bin or /usr/bin program? 
Again, a driver is the answer, 
time, user ID, or anything else you 
want into a log file (either one entry 
in a file for all programs or one entry 
in a log file for each different pro¬ 
gram). 

Second, it would use the 
execveO system call (or equiv¬ 
alent) to execute the real program— 
with the first argument being the 
concatenation of a hidden directory 
and the actual program name, the 
second argument being the argv 
pointer, and the third being a pointer 
to the unaltered environment. After 
all, you don’t want to pass the wrong 
path value to the actual program. 


Paul B. Reiber, Jr. 
American Robot Corp. 
Pittsburgh, Pa. 


A PORTABLE VERSION 
OF sma i 1 

After going to press with our April 
installment of “Wizard’s Grabbag,” 
Michael Poppers submitted another 
version of his smail Bourne shell 
script. The version published in 
April was specifically for Interac¬ 
tive’s is/3 Unix system on a VAX 
11/780. Here are some changes he 
suggested to make this script run on 
most Unix systems that have the 
necessary utility programs, such as 
whois or cut. 

First change lines 23 and 77 to 
echo > >$f i 1 e. 

Then in line 37 eliminate the 
pipe to the second instance of the 
cut command. Change the argu¬ 
ments to the first cut command to 
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100,000 software developers can’t be 
wrong.* 

UNIX is the chosen operating system for 
more than 100,000 software developers 
because it has the power they need. But 
developers aren’t the only people who need 
computing power. Any business that wants 
multi-users to access the same files at the 
same time or wants to simultaneously run 
multi-task operations... needs UNIX. At 
Dynacomp, we offer UniPlus + " System V 
by UniSoft Corp. For $1495. U.S. dollars 
you can run UNIX on the CompuPro R Sys¬ 
tem 816/8'"... a powerful 68K 
S-100 bus computer system that 


maximizes its memory for multi-user/multi¬ 
task operations. 

UniPlus + includes all the standard 
UNIX System V features PLUS perform¬ 
ance enhancements found only in 
UniPlus +. These features increase the 
portability, flexibility, and performance of 
UNIX, allowing an affordable operating sys¬ 
tem for program development, text prepa¬ 
ration, and general office use. 

If it’s time for you to upgrade to UNIX, 
call your local Full Service CompuPro Sys¬ 
tem Center in the United States or call 
Dynacomp in Canada for com¬ 
plete details. 


FROM 


210 W. Broadway 
Vancouver, B.C. 

V5Y 3W2 
(604) 872-7737 


COMPUTER SYSTEMS LTD. 


46-6535 Mill Creek Dr. 
Mississauga, Ont. 

L5N 2M2 
(416) 826-8002 


*AT&T estimates that there are more than 100,000 people currently developing software under UNIX. Dynacomp serves all of Canada and parts of 
Asia and the Pacific Rim. Call us for details and information on our full product line including Plexus. • UNIX is a trademark of Bell Laboratories, Inc. 
CompuPro is a registered trademark and System 816'E is a trademark of Viasyn Corp./CompuPro. UniPlus ■+ is a registered trademark of Unisoft 
Corp. AT&T is a registered trademark of AT&T Information Systems. 
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A superior spreadsheet on UNIX* 

As powerful as Lotus 1-2-3** 

• large spreadsheet 

• many business functions 

• complete GRAPHICS package 

• translates 1-2-3 models into Q-CALC 

• already ported to: VAX, Callan, 
Fortune, Nixdorf, Cyb, Plexus, Codata, 
Cadmus, Masscomp, SUN, etc. 

• ISVs/VARs—ideal for packaging with 
other software 

• translated into Japanese 

Available since July ’83 
For more information write/call 
Quality Software Products 
348 S. Clark Drive 
Beverly Hills, CA 90211 
213-659-1560 

"Lotus 1-2-3 is a trademark of Lotus Development Corp. 

* UNIX is a trademark of Bell Labs. 


WIZARD’S GR ABB AG 


be - d : - f 1 , which “cuts out” the 
contents of the first colon (“: ”) de¬ 
limited field from the password file 
(the user or log-in name) for storage 
in the variable, sender. Use -d: 
- f 1 > 5 if you wish to include the 
contents of the fifth (comment) field, 
too. □ 


Erratum for April 1985 “Wizard’s 
Grabbag 

The contents of line 7 in Figure 
2 should be all on one (long) line. 


“Wizards Grabbag” is a regular feature 
of Unix/World. Submit your shell 
scripts, C programs, or tips and tech¬ 
niques that ease the burdens of system 
administrators and programmers to 
“Wizard’s Grabbag,” Unix/World, 444 
Castro St., Suite 1220, Mountain View, 
CA 94041. Authors of published entries 
receive $50 for shell scripts, awk 
scripts, sed scripts, lex, yacc, and 
C programs, or tips. 

Please follow these guidelines for 
reader contributions: Write your shell 
scripts, C programs, and other code 
so that it is portable across different 
versions of the Unix system. If possible, 
it should run without change on Bell 
Version 7, Systems III and V, and 
Berkeley 4.x. Thus, you should use 
“universal” Unix utilities such as who 
am i (all systems) in lieu of whoami 
(Berkeley only), and the Bourne shell, if 
possible, when coding shell scripts. 

However, C shell scripts are also 
welcome because most of our readers 
now have access to this popular com¬ 
mand interpreter. Use the standard I/O 
library when writing C code. In addition, 
use the lint syntax checker to eliminate 
nonportable constructions, and compile 
the code with a portable C compiler such 
as p c c to help ensure portability. Hard¬ 
ware dependencies, such as terminal 
control sequences, should be eliminated 
or at least minimized and isolated to one 
code region or to a separate module. 
Keep your example as short as possible, 
say under 100 lines of code. 
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tion, appointment system, daily 
transactions, billing, and insurance 
processing. 

Reports of a transaction record 
and payment register (bank deposit 
slip) are automatically printed at the 
end of each day. In addition, the total 
fees collected are automatically en¬ 
tered at the end of each day into the 
checking account balance in the gen¬ 
eral ledger. 

The complete Office Manage¬ 
ment System will operate with a 
Tandy model 6000 microcomputer, a 
12- or 15-Mbyte hard-disk drive, 
and any type printer. The complete 
program software costs $600. 

Up to five additional work sta¬ 
tions may be added to this system. 



PERENNIAL 


UNIX 

VALIDATION 

SUITES 

System V 
4.2 BSD 
C Compiler 


408/737-3255 
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The programs are written in COBOL 
and use the Xenix (Unix) operating 
system. 

For more information, contact 
L.E. Olney, M.D., 1932 Brookside 
Rd., Kingsport, TN 37660; 615/ 
246-4155. 
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TERMINAL EMULATOR 
SOFTWARE FOR HP 9000 
SERIES 200 

Hewlett-Packard Company now 
offers terminal emulator software 
that allows HP 9000 Series 200 com¬ 
puters to act as interactive, asyn¬ 
chronous, alphanumeric terminals to 


Now you can stop worrying about cost 
overruns, missed deadlines and last 
minute revisions. With VUE menu-driven 
software you easily control schedules, 
budgets and resources according to 
your exact requirements. You can even 
output a variety of management reports, 
bar charts and diagrams directly to a 
printer or plotter. 

So, whether you're in construction, 
electronics, aerospace, manufacturing 


HP, dec, Data General, cdc, Prime, 
and other mainframes. 

Three of HP’s Pascal 2.1-based 
emulators for asynchronous, al¬ 
phanumeric terminals have been 
consolidated into one Pascal 3.0- 
based product. The HP 2392A and 
DEC VT 100 terminal emulator (HP 
98791B) replace the asynchronous- 
terminal emulator, the HP 2622A ter¬ 
minal emulator, and the VT 100 and 
HP 2622A terminal emulator. 

The Series 200 computer 
retains all of its engineering and 
computational capabilities, while the 
emulator provides datacomm and 
terminal-configuration menus that 
are equivalent to the HP 2392A and 
the VT 100 terminals. When used as 


or data processing, give us a call. We'll 
show you how VUE offers freedom from 
the phobias of project management. 

National Information Systems, Inc., 
20370 Town Center Lane, Suite 130, 
Cupertino, CA 95014. Tel: 408-257-7700. 
Telex: 750031. 

VUE 

For Enlightened Project Management. 


UNIX: AT&T 3B, Convergent Technology MegaFrame, Fortune, Gould, NBI, 
Pertec, VAX, Zllog System 8000, and more coming. 

Also: DEC 10/20, Honeywell DPS-6 and -8, HP 3000, IBM Mainframe VM/CMS, 

PDP-11, Perkin Elmer 3200, VAX VMS, and timesharing. 
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a bridge from engineering to another 
facet of a company’s operations, the 
enjulator offloads the host computer 
performing tasks on the Series 
200 workstation. 

The emulator supports the en¬ 
tire Series 200 (except Model 226) 
either a stand-alone configuration 
under the Pascal 3.0 operating 
item. It also supports Pascal 3.0 
pe ipherals and execution. 

For more information, contact 
yotir local HP sales office. □ 
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your correspondence to Unix/ 
World Magazine, New Prod¬ 
ucts Editor, 444 Castro St., 
Suite 1220, Mountain View, CA 
94041. Because of the large 
number of press releases we re¬ 
ceive, Unix/World cannot ver¬ 
ify the accuracy of claims made 
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We advise that you thoroughly 
test any product before buying. 
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Level 2B GKS. 
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Metafile. 

□ Full Simulation for Linetypes, 
Linewidths, Fill Areas, 
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□ Circles and Arcs, Ellipses 
and Elliptic Arcs, Bezier 
Curves. 

□ Ports Available on all 
Versions of UNIX. 
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NEC APCIII, IBM-AT, Silicon 
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Richest Development 
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UNIX Systems. 
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IS COMING 


PART 2 


BY STEVE HERSEE 


L ast month I discussed the 
reasons behind the current C 
standardization efforts, as 
well as the progress made in 
that endeavor at the June and Sep¬ 
tember 1984 meetings of the Ameri¬ 
can National Standards Institute 
(ANSI) X3J11 C standards committee 
meetings. 

In this month’s installment, I’ll 
bring you up to date on current status 
of the draft of the proposed C stan¬ 
dard, as well as the technical issues 
discussed, debated, and (hopefully) 
resolved at the committee’s Decem¬ 
ber 1984 meeting. 

That meeting was hosted by 
Motorola Inc. in Tempe, Ariz., from 
December 3-7. At this meeting, 29 
voting members were present, per¬ 
haps the largest number of voting 
members ever present since I 
started going to the meetings. Sev¬ 
eral new people, who plan to become 
voting members, also attended this 
meeting, so it looks as though sup¬ 
port for the committee is still 
growing. 

This meeting was the first at 


which all three parts of the standard 
document (environment, language, 
and library) were put together in final 
form. When the committee was first 
formed and a calendar set, the De¬ 
cember 1984 meeting was to approve 
a draft standard document to go out 
for informal comments. After the in¬ 
formal comments were received, the 
next step would be to send the draft 
standard out for formal comments. 
At that point, the journey toward a 
standard for C would be under way. 

At the start of the meeting many 
people were concerned that the doc¬ 
ument would be railroaded out of the 
committee before it was ready. Some 
were worried that they had had only 
seven days to review the document 
before this meeting and that the vol¬ 
ume of new material was too large to 
be able to approve during the meet¬ 
ing. Others felt that the committee 
vacillated on many issues; that is, a 
particular issue would go one way at 
one meeting and another way at the 
next. 

I felt that we should publish the 
document after this meeting because 
all of the arguments in favor of delay¬ 
ing the release (not ready, issues 
still open, and so on) would be just as 
valid at following meetings. 
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EDED 


TW 
NE 

We decided that the committee 
would need a two-thirds majority to 
publish the document. Any no votes 
would be listed with a reason why the 
voter felt the draft was not ready for 
publication. 

We all worked hard at the meet¬ 
ings, from 8 A.M. to 6 P.M., to pre¬ 
pare the document for publication. 
But as time ran out the number of 
changes made members uneasy 
about publishing a document they 
would not have a chance to review in 
its final form. We finally voted on Fri¬ 
day, about 20 minutes before the 
meeting was to adjourn. The vote 
was close—13 to publish and 12 not 
to p ublish. This was better than I ex¬ 
pected, considering all the talk I had 
heard. The vote did not carry the 
necessary two-thirds majority, 
tho jgh, and the committee finally ac¬ 
cepted a proposal to prepare the final 
document and send it, along with a 
letter ballot, to every committee 
member. 

If, during the two-week voting 
period, the draft standard received a 
two-thirds majority, then the docu- 
me it would be published and sent to 
the cbema (Computer Business 
Equipment Manufacturers Associa¬ 
tion) Secretariat. Once cbema had 
the draft, interested parties wanting 
to submit comments to the commit¬ 
tee could obtain a copy from cbema 
for a nominal fee. 

The draft will say that C compi¬ 
lers should not be implemented from 
this draft because additional changes 
might be made. The committee is 
aware that many compilers might be 
chc nged to add features published in 
this draft. Please, if you are going to 
modify your compilers and are not 
part of the X3J11 committee, then 
join the committee. Because many of 


the committee members are also 
vendors of C compilers (like myself), 
those members will have the inside 
track on changes to the draft after it 
has been published. 

If you cannot attend the meet¬ 
ings, you can sign up to receive mail¬ 
ings from the meetings. The commit¬ 
tee does act upon the many written 
submissions it receives, and we 
would like more people to comment 
on the work we are doing. If you are 
interested, please feel free to contact 
Jim Brodie of Motorola at 602/438- 
3456. Now I’ll discuss some specific 
issues raised at the last meeting. 


A CHANGE IN THE USE OF 
THE & OPERATOR 

The C language understands the op¬ 
erator & to mean “address of. ” So if 
you say a = & b ; , this means let 
a equal the memory address of the 
variable b. In current C, this does not 
hold true if b is an array. If b were 
declared as char b [ 5 ] ; , then 
the statement a = & b ; would 
cause an error in some C compilers. 

In Kemighan and Ritchie’s book, 
The C Programming Language (also 
known as “K&R”), the authors 
clearly point out that using the & op¬ 
erator with arrays is illegal (page 94). 
Funny, but I did not know that any 
laws had been passed about this is¬ 
sue—but then, I have always pre¬ 
ferred the use of the word invalid to 
illegal. K&R is specific: If you want 
the address of an array and also want 
to use the & operator (so that when 
you read the code you can say “ad¬ 
dress of”), you must say a = &b 
[ 0 ] ;. 

We on the committee had long 
arguments about common practice. 
How many people have been taught 
that, in order to get the address of an 
array, they must say just the array 


name or take the address of the first 
element of the array. I prefer to have 
the & in front of the array to remind 
me when an address is needed. At 
the September meeting, the commit¬ 
tee voted not to allow the & in front 
of array names. 

I figured I had lost on this issue, 
but to my surprise I found that I was 
saved (at the December meeting) by 
the cookie. The what? The cookie, 
which I learned about while on the 
committee, is an item that library 
functions pass around to keep items 
that may change from computer to 
computer. A good example is the 
time-of-day function. The standard 
defines a typedef type of 
t ime_t, which defines the stor¬ 
age needed to keep the time of day 
for a particular computer, as in the 
example in Figure 1. 

If t ime_t says that t imel 
is a long type, then the old K&R rules 
are fine. But what if the t i m e t is 
an array of i n t s to hold the time in 
microseconds? Because the st andard 
allows the compiler vendor to define 
any type to t ime_t, you cannot 
write a portable program that passed 
the address of an item defined! with a 
supplied typedef. Since you 
don’t necessarily know whether such 
items are arrays, the standard now 
allows you to use the & operator with 
array names and function names. 


PREPROCESSOR 
ARITHMETIC 

If you have a program that yo 
to be as portable as possible, 
find yourself becoming con 
about how the preprocesso 
putes values. Some prograi 
the preprocessor to tell them 
of an “int.” (You can see an e 
of this in Figure 2.) 

Does the code in the e 
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time_t timel; 
time(4timel); 


FIG 


URE 1: EXAMPLES OF TIME-OF-DAY TO DEFINE STORAGE NEEDED 


#if(Oxffff ♦ 1) 

#endif 


FIGURE 2: PREPROCESSOR DEFINES int AND SIGNED OR 
UNSIGNED CHARACTERISTICS OF A PROGRAM 


easel ..6: a=b; 

case 200 .. 204: a = c; 


FIGURE 3: PROPOSED SYNTAX OF CASE RANGE ADDITIONS 


case 1 : 
case 2: 
case 3: 
case 4: 
case 5: 

case 6: a=b; 

case 200: 

case 201 : 

case 202: 

case 203: 

case 204: a = c: 


FIGURE 4: POSSIBLE EXAMPLES OF CASE RANGE CODE 


compile or not? If the preprocessor 
does its arithmetic in 32-bit blocks, 
the expression in the i f is nonzero; 
if the arithmetic is 16 bits, then i f 
hap a zero value. 

You might say this is a nice trick 
thk allows the programmer to find 
out information not otherwise avail¬ 
able. The problem comes when you 
use a C cross-compiler that uses the 
native preprocessor, leaving the pro¬ 


grammer wondering which arithme¬ 
tic to use, the target or host. The 
standards committee voted to make 
the arithmetic appear to be done in 32 
bits. This allows all preprocessor an¬ 
swers to be the same, and the stan¬ 
dard provides several include 
files that give programmers the infor¬ 
mation they need. 

At the September meeting the 
committee voted 21 for, 5 against, 


and 4 undecided to add case ranges to 
the language. The proposed s;mtax is 
shown in Figure 3. 

At the December meeting the 
committee voted case ranges out of 
the language. This shows that the 
committee can reverse its stand on 
issues and, more important, it shows 
that if people can make a good case 
for their position, they can have an 
effect on the committee. Personally, 
I was in favor of case ranges because 
I think that the code in Figure 3 is 
more readable than that in Figure 4. 

Some of the committee mem¬ 
bers have a problem using the “ . . ” 
operator from Ada to specify i\ range. 
When the compiler sees 1 . . 5, it 
could interpret this either as a range 
from 1 to 5 or the real number 1, fol¬ 
lowed by the real number . 5. I think 
the issue of ranges in case: state¬ 
ments is not dead yet and may just be 
waiting for the proper syntax. Any¬ 
one who would like to comment on 
whether case ranges are necessary 
(and who has suggestions for a good 
syntax) is welcome to contact me. 


FORTRAN ISSUES 

With the number of C users growing 
each day, it is not surprising that 
some users have come over from the 
fortran camp to C. The committee 
has had some input from fortran 
users concerning changes they would 
like to see in the C language that 
would make C a better replacement 
for their old favorite. It seems that 
fortran users have two major prob¬ 
lems with C. Their first objection is 
that the current C language requires 
all real-number arithmetic to be done 
at the double-precision level. They 
expect an expression done entirely 
with variables declared as float, to be 
evaluated using float precision. Sec¬ 
ond, C does not allow programmers 


JULY 1985 


UNIX/WORLD 


113 




























TRAINING 


CALENDAR 


Informix Relational Database: 

July 5-12, Cincinnati, Ohio. Contact 
Information Technology Develop¬ 
ment Corp. 513/741-8968. 

Unix Concepts: July 8-10, Boston, 
Mass. Contact Intelligent Training 
Solution, 916/321-5300. 

Software Engineering and 
Quality Assurance: July 8-12, 
Washington, D.C. Contact Dick 
White, 800/424-9773 or 202/676- 
8516. 

Unix—A Hands-On Introduc¬ 
tion: July 9-12, Los Angeles, Calif. 
Contact Ruth Dordick, ICS, 800/ 
421-8166. 


16-Bit Microprocessors: July 9- 
12, Washington, D.C. Contact Ruth 
Dordick, ICS, 800/421-8166. 


Local-Area Network Seminar: 

July 10-12, San Francisco, Calif. 
Contact csi, 408/725-1568. 


World Computer Graphics: July 
10-12, New York, N.Y. Contact 
World Computer Graphics Associa¬ 
tion, 202/775-9556. 


Unix System Administration: 

July 11-12, Boston, Mass. Contact 
Intelligent Training Solution, 916/ 
321-5300. 


Unix Perspectives: July 14, Bos¬ 
ton, Mass. Contact Information 
Technology Corp., 513/741-8968. 

National Computer Conference 
of ’85: July 15-18, Chicago, Ill. 
Contact Molly Finney, 703/620- 
8938. 

Unix For End-Users: July 15-19, 
Cincinnati, Ohio. Contact Informa¬ 
tion Technology Development 
Corp., 513/741-8968. 

Programming in C—A Hands- 
On Workshop: July 16-19, Los 
Angeles, Calif. Contact Ruth Dor¬ 
dick, ics, 800/421-8166. 


Introduction to Datacomm and 
Networks: July 16-19, Los An¬ 
geles, Calif. Contact Ruth Dordick, 
ics, 800/421-8166. 

IBM Futures Forum: July 18-19, 
Chicago, Ill. Contact Lynn Bentley, 
Gartner Group Inc., 203/967-6723. 


To further the education of Unix 
systems users and professionals, 
Unix/World each month provides a 
calendar of events as a service to our 
readers. Please send information about 
your seminar, trade show, or course to 
Calendar Editor, Unix/World Maga¬ 
zine, 444 Castro St., Suite 1220, 
Mountain View, CA 94041. All items 
should include a title, a brief descrip¬ 
tion of the course, seminar, or trade 
show, the date of the event, the city 
and state where it will be held, the 
name of the sponsoring company or 
organization, and an address and phone 
number for further information. Please 
submit all items at least four months in 
advance. □ 
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a = (b * c) * (d * e); 


fig 


URE 5A: SAMPLE EXPRESSION FOR EVALUATION 


1 . b*c 

2. d * e 

3. (1 ) * (2) 


FIGURE 5B: HOW EXPRESSION WOULD BE EVALUATED IN 
FORTRAN 


t empl = b * c ; 
temp2 = d * e; 
a = tempi * temp2; 


FIGURE 6: FORCING EVALUATION ORDER WITH C 


a = + ( b * c) * +(d * e); 


FIGURE 7: PROPOSED C SYNTAX FOR FORCING EVALUATION 
ORDER 


m|i 

F 

C 

tc 


to specify the order in which parts of 
an expression are to be evaluated; 
programmers must assign expres¬ 
sion elements to temporary variables 
to ensure a specific order (see Figure 
5A). 

If the example in Figure 5 were 
in FORTRAN, you would know that the 
order of evaluation would be as 
shown in Figure 5B. In the C lan¬ 
guage, the order of evaluation is not 
known—the compiler is free to do the 
multiplication in any order it wishes. 
If C programmers are worried about 
overflow or underflow, they now 
ust code the example as shown in 
gure 6. 

fortran programmers say, “If 
is so great, why doesn’t it allow us 
specify the order of evaluation?" 
Tlo address this issue, the committee 
is trying to modify the C language in 


order to give programmers control 
over the order of evaluation—as well 
as the evaluation of all float expres¬ 
sions—so that all arithmetic is done 
using float precision. The current 
proposal for forcing the order of eval¬ 
uation is to add a unary plus or minus 
to the expression, as shown in Figure 
7. This tells the compiler that it must 
fully evaluate the expressions inside 
the scope of the unary operator be¬ 
fore going on. I feel that the entire 
issue of helping fortran program¬ 
mers is going to elicit much comment 
from the current C programmer 
base—I expect there to be a lot of 
changes in this area before all parties 
are in agreement. 

In future installments I will con¬ 
tinue to bring Unix/World readers 
up to date on the developments at the 
X3J11 committee meetings, as well 


ju 
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as on the overall progress of tjhe pro¬ 
posed C standard. Until ther, write 
and let me know your feelings on the 
issues I’ve covered, as well as any 
others you might feel are pert inent to 
the C standardization efforts. □ 


Steve A. Hersee is currently the vice presi¬ 
dent of marketing at Lattice Inc., a devel¬ 
oper of the Lattice C compiler for the ibm pc 
and cross and native compilers for the 
Unix system. Mr. Hersee is a member of 
the ansi X3J11 C standards committee. 
Readers can send their comments to Mr. 
Hersee at the following address: P. 0. Box 
3072 , Glen Ellyn, IL 60138. 
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Sales 


Technical 
Support Analysts 


Sun Microsystems, Inc., is a leader in the computer 
industry today, due to the development our general- 
purpose workstations. 

We are looking for individuals to provide pre and 
post software sales support. You will need a strong 
knowledge of UNIX*, with internals experience 
(notably device drivers) strongly recommended. 
Experience with 68010-based workstations would 
be helpful. 

We offer an excellent salary, comprehensive 
benefits and opportunities for personal recognition 
and professional growth. Please send a resume to: 

District Sales Manager, Mail Stop #341, 
Sun Microsystems, Inc., 3803 E. Bayshore 
Road, Palo Alto, CA 94303. An equal 
opportunity employer. 

•UNIX is a trademark of Bell Laboratories 



Readers who have computer merchan¬ 
dise or services to sell, buy, or trade and 
who want to be included as a classified 
advertiser in UNIX/WORLD Magazine 
should write to: Advertising Depart¬ 
ment, Tech Valley Publishing, 444 Castro 
Street, Suite 1220, Mountain View, CA 
94041. 415/940-1500. The rate for the 
classified section is $12 per line. The 
deadline for ads is the 20th of the 2nd 
month prior to publication. Please include 
complete name and address in every ad. 
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WMZ Consulting Grou t )—System 
Consultants for total implementation of 
information systems. WMZ provides 
design, implementation, training, and on¬ 
going support. We have experts in UNIX 
on staff and we are not committed to any 
software or hardware. We sell solutions 
not iron. Call (415) 945-2070, or write 
WMZ Consulting Group, 1483 Ashwood 
Drive, Martinez, CA 94553. 
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dates and jobs in the Unix 
field. Please give us a call; 
send a resume; or request a 
free Resume Workbook & 
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professional employment 
firm managed by graduate 
engineers. 

800 - 231-5920 

P.O. Box 19949, Dept. UW 
Houston, TX 77224 
713-496-6100 
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TRAINING 


STARTER KIT 


AN ON-LINE 
CALCULATOR 


BY BILL TUTHILL 


I 


nor 
only 
begini 
com i 


n many ways, the arbitrary- 
precision calculator be typifies 
Unix system software. To begin 
with, it is neither well known 
widely used, being described 
in a research paper and not in 
ning documentation. Second, it 
es from Bell Labs and has been 


51 be 
‘6 + 33 
‘19 

‘19 - 87 
-38 

‘ 024 * 4 
‘1096 
'00/3 
33 

00 % 3 

;> A 32 
‘1294967296 
(|u i t 


FIGURE 1: SOME CALCULATIONS 
USING be 


on every Unix system release since 
1978; Berkeley gets no credit for it. 
Third, it is taciturn: There is no 
prompt, the only output being error 
messages and the answer. Its two- 
letter name has little mnemonic 
significance. Fourth, and perhaps 
most importantly, aside from the 
user interface, be is superior to 
more glamorous software running on 
systems such as cp/m and ms-dos. 

All commercial desk calculators 
overflow at some point. You can 
verify this on your best calculator by 
continually multiplying a number by 
itself. Spreadsheet programs and 
basic interpreters, too, can only 
handle numbers of a certain size. 
The be program, by contrast, does 
not overflow until memory is ex¬ 
hausted. In practice, two 500-digit 
numbers can be multiplied to prod¬ 
uce a 1000-digit number in about 10 
seconds. Division is equally fast and 
is accurate up to 99 decimal places. 
Aside from normal arithmetic, be 
'Can calculate powers, square roots, 
and trigonometric functions. In fact, 
it is a complete programming lan¬ 
guage with a C-like syntax. 

To begin using the calculator, 
just type be after the shell prompt. 


Use 41 + ” to add, 44 - ” to subtract, 

to multiply, and “/” to divide. 
Division normally yields no decimal 
places, but you can change this. The 
modulo operator gives tiie re¬ 
mainder after division, and the ex¬ 
ponentiation operator “ A ” takes a 
number to a power. To get back to 
the shell, type quit, as shewn in 
Figure 1. 

As you can see, be lops ofjf deci¬ 
mal places after dividing. If you want 
more precision, set the scale to 
however many decimal places you 
want, as long as this value is less 
than 100. Figure 2 shows divisions 
and square roots when the s|;ale is 
set to 5 and 99. 

Generally, be does not wlant to 
print more than 70 characters per 
line, so it prints a backslash and con¬ 
tinues on the following line if there 
are more than 70 digits ip the 
answer. 

A CONVENIENT FEATURE 


One convenient feature of be 
it converts decimal numbers 
or hexadecimal, and vice 
Actually, it can convert any 
any other base and can p< 


is that 
octal 
versa. 

to 
drform 


ta 


5, be 
!>ca 1 e = 5 
00/3 
33.33333 
liqr t (2) 

'.41421 
;>ca 1 e = 99 


00/3 

33.3333333333333333333333333333333333333333333333333333333333333333333\ 

333333333333333333333333333333 

liqr t (2) 

.41 421 3562373095048801688724209698078569671 8753769480 731 76 67973799073V 
2478462107038850387534327641572 


FIG 


LIRE 2: DIVISION AND SQUARE ROOTS WITH THE SCALE SET TO 5 AND 99 
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% be 
obase=8 
8 

1 0 

9 

1 1 

10 
1 2 

obase=16 
1 0 
A 
1 1 
B 

12 

C 

13 
D 

14 
E 

15 
F 

16 
1 0 


FIGURE 3: CONVERTING DECIMAL 
NUMBERS TO OCTAL AND 
HEXADECIMAL NOTATION 


% be -1 
a(1) * 4 

3.14159265358979323844 
define p( ) { 

return (a(1 ) * 4) 

> 

P(> 

3.14159265358979323844 


FIGURE 4: A FUNCTION TO 
CALCULATE PI BY MULTIPLYING 
THE ARCTANGENT OF ONE 
BY FOUR 

arithmetic in bases besides decimal. 
The built-in variable obase sets the 
output base, whereas ibase sets 
the input base. Figure 3 shows how 
you can convert decimal numbers to 
octal and then to hexadecimal 
notation. 

Programmers find it helpful to 


STARTER KIT 


define f(n) { 

auto i , x 

for (i = x = 1; i <= n; i++) { 
x * = i 

} 

return(x) 


FIGURE 5: A FUNCTION THAT COMPUTES N FACTORIAL 


be() { 

/usr/bin/bc SHOME/.beinit 
} 


FIGURE 6: CHANGING be TO YIELD GREATER DECIMAL PRECISION 
FOR THOSE USING THE BOURNE SHELL ON SYSTEM V.2 


be able to convert octal and hexad¬ 
ecimal numbers into decimal no¬ 
tation. You can do this by setting 
ibase to 8 and 16, respectively. 
You can also convert binary numbers 
into decimal by setting ibase to 2. 

The -1 option loads a math li¬ 
brary that includes functions for cal¬ 
culating sine, cosine, arctangent, 
natural logarithm, the exponential, 
and Bessel functions of integer 
order. For example, it is always pos¬ 
sible to calculate pi by multiplying 
the arctangent of one by four. You 
can even package this up as a func¬ 
tion, as shown in Figure 4. 

Because the -1 math library 
sets the scale to 20, the function 
p () above returns pi to 20 decimal 
places. More complicated function 
definitions are possible, using C lan¬ 
guage control-flow constructs such 
as the for loop. Functions need not 
involve the math library. Figure 5 
presents a function that computes N 
factorial. 

Most of the time, users want 
more decimal precision than be 
gives by default. Fortunately, be¬ 
cause be reads the file specified as 


a command-line argument before 
reading from the terminal, you can 
easily customize be to yield greater 
decimal precision. F ; rst, place the 
following line in a file named 
. be i n i t in your home directory: 
scale = 5. If you’re using the C 
shell, create the following alias: 
alias be be ~/.bcinit. If you’re 
using the Bourne shell on System 
V.2, create the function shown in 
Figure 6. 

After you have made this 
change, division will always yield five 
decimal places of precision. If you 
want fewer or more decimal places, 
just change the value of scale 
interactively. □ 


Bill Tuthill is a member of the technical 
staff at Sun Microsystems, Mountain 
View, Calif He was previously a systems 
analyst at Imagen Corp. and a pro¬ 
grammer at UC Berkeley. 
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TRENDS 


THE EFFECTS 

The problems that hard-core com¬ 
puter nerds might face as they grow 
older are pretty obvious. When peo¬ 
ple nave spent most of their time in 
front of the computer CRT/keyboard, 
the) r won’t have had time to learn how 
to deal effectively with people, both 
in working and personal relation¬ 
ships. Sooner or later, such deficien¬ 
cies will make themselves known, 
with unhappy results almost a 
certainty. 

But there is another issue as 
well. Not only do such deficiencies af¬ 
fect the individuals themselves, they 
often affect society at large. There 
are a variety of ways in which this can 
occur. Persons who have not learned 
how to interact effectively with oth¬ 
ers may have a difficult time in most 
working environments, where effec¬ 
tive teamwork (even when the task is 
programming!) is frequently of cru¬ 
cial importance. Not everyone work¬ 
ing with computers has the some¬ 
times dubious privilege of being his 
own boss and xiot having to interact 
clos ely with co-workers. 

One might also wonder about 
the “ethical” sense that develops 
within people who have most of their 
primary interactions with computers 
rather than people. The twisted “eth¬ 
ics’ of some computer “crackers,” 
who get their kicks from breaking 
intc other people’s systems but who 
don’t think twice about the rights of 
tho $e people, might be one example. 
There are a variety of other scenarios 
that could be brought up as well, but 
let’s not belabor the point here—you 
get the idea. 

WHAT TO DO? 

At this juncture, I’m supposed to 
come up with some brilliant solution 
for the problems I’ve outlined. Well, 
it’s not terribly brilliant, but at least 
one aspect of a way to help avoid 
some of the problems does seem 
pretty clear—it’s pretty simple, too. 


sync 


There’s no reason to discourage chil¬ 
dren from learning about, enjoying, 
and spending time with computers. 
But efforts should be made to detect 
when children are beginning to en¬ 
gage in such activities to the exclu¬ 
sion of most other extracurricular 
and interpersonal behavior. 

If such a situation is detected, 
it’s important that adults help to steer 
such children in the direction of activ¬ 
ities that will require some more sig¬ 
nificant person-to-person interaction 
than sitting at the computer can pro¬ 
vide. Certainly we don’t want to ex¬ 
clude the computer from the palette 
of children’s free-time choices; it can 
indeed be a useful way to spend some 
of their time. But neither should we 
allow them to become so totally ab¬ 
sorbed by this one activity that they 
exclude other useful activities that 
can also contribute to their intellec¬ 
tual and social development. 

We want children to become 


•mini 


computer-aware, and we cei 
should help encourage their in 
if they show particular aptitudi 
ward working with computers, 
by helping them to avoid becoi 
tally oriented toward such te 
ogy, we are doing both them 
ourselves, a favor in the long nji 
we need more computer ne: 
think not. □ 

--Lauren-- 
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THE NEW 

COMPUTER 

NERDS 


BY LAUREN WEINSTEIN 


Beware! A new 
generation of 
computer “nerds” 
is on the way. 
Many have al¬ 
ready arrived, and 
their numbers will 
be increasing rap¬ 
idly in the near fu¬ 
ture. It's not a laughing matter—it 
could affect our lives and culture in 
ways we would never imagine, many 
of which may well be quite negative. 

The first important point to re¬ 
alize is that you can't necessarily 
identify computer “nerds” by their 
looks. Well, not always, anyway. Of 
course, we're all familiar with the 
popularized image of the (virtually al¬ 
ways male) computer nerd, so 
there's no point in describing him 
here. To be sure, such images were 
based on a certain archetypical vari¬ 
ety of person who indeed did (and 
does) exist. But don't be misled into 
believing that all computer nerds can 
be so easily pinpointed. 

In reality, computer nerds are 
ultimately identified not by the way 
they look, but by their actions and 
value systems. To my mind, a com¬ 
puter nerd is a person whose primary 
focus of life, including both work and 
play, both job time and spare time, 
focuses on computers to the exclu¬ 
sion of virtually all else, particularly 
other people. 

Computer nerds, by this defini¬ 
tion, can be of either sex (though 
males still greatly predominate) and 
may in some cases show none of the 


appearance-related traits that have 
come to be associated with such 
personalities. 

We can find computer nerds of 
widely varying ages, but until fairly 
recently the characteristics of com¬ 
puter nerdism didn’t extend back to 
very young children. This is com¬ 
pletely understandable since it is only 
in recent years that computers have 
become available to many younger 
people. Individuals of my generation 
didn’t usually have any significant di¬ 
rect access to computers until we 
reached college. 

That's all changed now, of 
course. Comparatively sophisticated 
computers can be found even in the 
smallest of primary schools, not to 
mention elementary/secondary 
schools, colleges, and universities. 
Children are exposed to these com¬ 
puters from the very earliest ages, 
and that doesn’t even include the chil¬ 
dren whose parents have bought 
computers for the home and encour¬ 
age their young children to play with 
the units. 

It is from the ranks of the young 
children, the children who are grow¬ 
ing up with computers practically 
from birth, that the new generations 
of computer nerds will evolve. And 
just as there are incredibly more 
computers available now than, say, 
10 or 15 years ago, so there will be 
more computer nerds as well, as I de¬ 
fined them above. 

THE PROBLEM 

Well, why should we be concerned 
about computer nerds? Shouldn’t we 
just let them alone to live as they wish 
and let them merrily type their lives 
away? No, we should not. When 
one's life is totally absorbed with ma¬ 
chines, particularly complex ma¬ 
chines like computers, it is very diffi¬ 
cult, perhaps impossible in many 
cases, to develop a healthy under¬ 


standing of, and respect for, people. 
And like it or not, we live in a world 
not only of machines, but of people as 
well! 

The handwriting is already on 
the wall ... er ... the characters 
are already on the screen. Talk to 
many school teachers and you’ll hear 
stories of youngsters who spend all 
their free time clustered around the 
classroom computers. After school, 
you can often find these same chil¬ 
dren over at the nearby Radio Shack 
or similar establishment, where they 
spend the remainder of the afternoon 
with the computers down there! 
When asked, many of these children 
will tell you that “their best friend” is 
the computer. 

I'm not saying that it would be 
better for these kids to be in street 
gangs, but I am suggesting that for 
many of these children, their single- 
minded infatuation with computers 
could well lead toward significant per¬ 
sonal problems down the line, prob¬ 
lems that could last indefinitely into 
adulthood. Remember, children can 
now get “hooked” by computers at an 
incredibly young age. And the ma¬ 
chines can indeed be seductive. They 
can provide a sense of power over an¬ 
other (albeit nonhuman) entity. They 
can be manipulated and controlled, 
and (most of the time, anyway) they 
don’t threaten you or place you in 
“uncomfortable” situations, unlike 
the sorts of things that can arise when 
dealing with other children out on the 
playground. 

In many cases, teachers and 
parents are perfectly thrilled to see 
their children spending so much time 
in what is viewed as a “productive” 
manner. Often they don't seem to re¬ 
alize that even a “hobby” with so 
much potential for constructive 
learning can be something of a nar¬ 
cotic when it blocks out all else, and 
it's all the more powerful for being in¬ 
troduced at an early age. 
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How can you write software 
that’s a clear best seller? By 
writing applications for the 
growing number of products 
based on UNIX System V. 
And by making sure your 
software conforms to the 
System V Interface Definition. 

Your software written under the 
Interface Definition can run on current and 
future releases of AT&T’s UNIX System V, 
as well as standard System V derivatives 
offered by AT&T licensees. With such a 
large potential market, it pays to go by 
the book. 


prise standard System V. You’ll have the 
information needed to write applications 
that are portable across current and future 
System V environments—without modifi¬ 
cation. Applications that are virtually 
hardware independent, from personal 
computers to mainframes. 

Software developers will be able to 
sell more software to more customers for 
a broader range of hardware products. 
VARs will be able to offer more customers 
a wider choice of System V-based equip¬ 
ment—with a ready supply of software 
to run on it. And that means greater 
profitability. 


Guidelines you can profit by 

The Interface Definition precisely iden¬ 
tifies features and functions that com- 


A standard you can bank on 

AT&T is committed to UNIX System V as 
a universal standard. It’s gaining wide 


commercial acceptance. 

We plan to preserve the integrity of 
UNIX System V and promote the compat¬ 
ibility between System V and its deriva¬ 
tives. Conforming to the System V 
Interface Definition ensures your applica¬ 
tions will meet these high standards. And 
satisfy end-user needs. 

To profit from the growing demand 
for software written by the book, order 
the System V Interface Definition—at 
$37.00 plus tax. Call 1-800-432-6600 and 
ask for Operator 382. You can charge your 
order to any major credit card. 
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